本文用到的表结构

create table stu(
stu_id int auto_increment primary key,
name varchar(30) not null,
age smallint,
cls_id int
);

1、order by  排序 默认升序

1)单列排序,只按照某列排序

mysql> select name, age from stu order by name;
+-----------+------+
| name | age |
+-----------+------+
| guojing | 25 |
| huangrong | 23 |
| lisi | 20 |
| wangwu | 17 |
| xiaolongn | 14 |
| zhangsan | 18 |
| zhangsan | 18 |
| zhangsan | 15 |
| zhangsan | 17 |
| zhaoliu | 15 |
+-----------+------+
10 rows in set (0.00 sec)

2)多列排序,当第一列值相同时,按第二列排序,以此类推多列排序

mysql> select name, age from stu where name='zhangsan' order by name,age;
+----------+------+
| name | age |
+----------+------+
| zhangsan | 15 |
| zhangsan | 17 |
| zhangsan | 18 |
| zhangsan | 18 |
+----------+------+
4 rows in set (0.01 sec)

3)在要进行排序的字段后边添加。降序,"order by 字段 desc"   升序  "order by 字段 asc"  没有说明的将默认升序

mysql> select name, age from stu order by name desc, age asc;
+-----------+------+
| name | age |
+-----------+------+
| zhaoliu | 15 |
| zhangsan | 15 |
| zhangsan | 17 |
| zhangsan | 18 |
| zhangsan | 18 |
| xiaolongn | 14 |
| wangwu | 17 |
| lisi | 20 |
| huangrong | 23 |
| guojing | 25 |
+-----------+------+
10 rows in set (0.00 sec)

2、distinct  将查询的结果去掉重复值

mysql> select distinct name from stu;
+-----------+
| name |
+-----------+
| zhangsan |
| lisi |
| wangwu |
| zhaoliu |
| guojing |
| huangrong |
| xiaolongn |
+-----------+
7 rows in set (0.00 sec)

3、聚合函数

聚合函数也称分组函数,总共有5个:聚合函数忽略空值

  • count    统计记录总数
  • sum     求和
  • avg      求平均值
  • max     取最大值
  • min      取最小值

1)求stu表的总记录数

mysql> select count(*) as 总记录数 from stu;
+--------------+
| 总记录数 |
+--------------+
| 7 |
+--------------+
1 row in set (0.00 sec)

2)求stu表的学生总最大值,最小值,平均值,年龄

mysql> select max(age) as 最大值, min(age) as 最小值, avg(age) as 平均值, sum(age) as 年龄总和 from stu;
+-----------+-----------+-----------+--------------+
| 最大值 | 最小值 | 平均值 | 年龄总和 |
+-----------+-----------+-----------+--------------+
| 25 | 14 | 18.8571 | 132 |
+-----------+-----------+-----------+--------------+
1 row in set (0.00 sec)

4、分组查询

分组查询中只能使用聚合函数与参与分组的字段

1)查询每个班的年龄最大值,最小值,平均值,总和

mysql> select cls_id, max(age), min(age), avg(age), sum(age) from stu group by cls_id;
+--------+----------+----------+----------+----------+
| cls_id | max(age) | min(age) | avg(age) | sum(age) |
+--------+----------+----------+----------+----------+
| 1 | 18 | 14 | 16.0000 | 32 |
| 2 | 25 | 17 | 21.0000 | 42 |
| 3 | 23 | 15 | 19.3333 | 58 |
+--------+----------+----------+----------+----------+
3 rows in set (0.00 sec)

2)查询每个班的人数

mysql> select cls_id, count(*) from stu group by cls_id;
+--------+----------+
| cls_id | count(*) |
+--------+----------+
| 1 | 2 |
| 2 | 2 |
| 3 | 3 |
+--------+----------+
3 rows in set (0.01 sec)

4、having

having子句用于分组后的数据筛选,不用where的原因是where不能和聚合函数一起使用,这里涉及到sql的执行顺序的问题

1)查找平均年龄大于18的班级

mysql> select cls_id, avg(age) from stu group by cls_id having avg(age) > 18;
+--------+----------+
| cls_id | avg(age) |
+--------+----------+
| 2 | 21.0000 |
| 3 | 19.3333 |
+--------+----------+
2 rows in set (0.00 sec)

mysql "order by" "distinct" "group by" "having"的更多相关文章

  1. mysql中函数DISTINCT,group by,CONCAT及GROUP_CONCAT的使用

    一:DISTINCT 在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供有distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是 ...

  2. mysql distinct&group by 应用

    在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供 有distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记录的 ...

  3. mysql 中order by 与group by的顺序

    mysql 中order by 与group by的顺序 是: select from where group by order by 注意:group by 比order by先执行,order b ...

  4. mysql 去除重复 Select中DISTINCT关键字的用法 在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供 有distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记录的所有值。其原因是 distinct只能返回它的目标字段,而无法返回其它字段,这个问题让我困扰了很久,用distinct不能解决的话,

      在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供 有distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记 ...

  5. ORDER BY,GROUP BY 和DI STI NCT 优化

    读<MySQL性能调优与架构设计>笔记之ORDER BY,GROUP BY 和DI STI NCT 优化 2015年01月18日 18:51:31 lihuayong 阅读数:2593 标 ...

  6. 转 SQL Union和SQL Union All两者用法区别效率以及与order by 和 group by配合问题

    SQL Union和SQL Union All两者用法区别效率以及与order by 和 group by配合问题 SQL Union和SQL Union All用法 SQL UNION 操作符 UN ...

  7. mysql中select distinct的用法

    在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供有distinct这个关键字来过滤掉多余的重复记录只保留一条,但 往往只用它来返回不重复记录的条数,而不是用它来返回不重记录的 ...

  8. Hive中笔记 :三种去重方法,distinct,group by与ROW_Number()窗口函数

    一.distinct,group by与ROW_Number()窗口函数使用方法 1. Distinct用法:对select 后面所有字段去重,并不能只对一列去重. (1)当distinct应用到多个 ...

  9. mysql中去重 distinct 用法

    在使用MySQL时,有时需要查询出某个字段不重复的记录,这时可以使用mysql提供的distinct这个关键字来过滤重复的记录,但是实际中我们往往用distinct来返回不重复字段的条数(count( ...

随机推荐

  1. /etc/profile /etc/profile .bash_profile .bashrc解释

    1.用户登录系统时,bash首先执行/etc/profile配置文件和/etc/profile.d/目录下的配置文件,这些配置文件对系统的所有用户都有效,它们设置了普遍性的环境变量. 2.然后,Bas ...

  2. 《转》python学习(11)-表达式和语句

    转自 http://www.cnblogs.com/BeginMan/p/3164600.html 一.Python语句 if语句.else语句.elif语句.条件表达式.while语句.for语句. ...

  3. jQuery的一些静态方法

    // 该方法被绑定在jQuery对象上,只能通过$.noConflict()调用 noConflict: function( deep ) { // 取消$在window上的绑定,方法是将_$绑定到w ...

  4. war部署到tomcat

    gs-rest-service-0.1.0.war复制到tomcat-9.0.0.M17\webapps\ 打开server.xml,这Host节点,加入<Context path=" ...

  5. sendfile Linux函数

    现在流行的 web 服务器里面都提供sendfile 选项用来提高服务器性能,那到底 sendfile 是什么,怎么影响性能的呢? sendfile 实际上是 Linux 2.0+ 以后的推出的一个系 ...

  6. 完全卸载Oracle数据库软件

    软件环境: 1.Windows xp+ORACLE 8.1.7 2.ORACLE安装路径为:C:\ORACLE 实现方法: 1. 开始->设置->控制面板->管理工具->服务 ...

  7. Nginx学习之keepalive

    当然,在nginx中,对于http1.0与http1.1也是支持长连接的.什么是长连接呢?我们知道,http请求是基于TCP协议之上的,那么,当客户端在发起请求前,需要先与服务端建立TCP连接,而每一 ...

  8. C语言位操作--判断整数的符号

    关于衡量计算操作的方法: 当为算法统计操作的数量的时候,所有的C运算符被认为是一样的操作.中间过程不被写入随机存储器(RAM)而不被计算,当然,这种操作数的计算方法,只是作为那些接近机器指令和CPU运 ...

  9. jenkins遇到含中文路径的SVN地址时认证通不过

    安装插件:http://mirror.xmission.com/jenkins/plugins/subversion/2.5/subversion.hpi 可以解决svn中文目录问题 百度云:http ...

  10. 9.11 Django关于母版语言的灵活用法

    2018-9-11 12:45:38 还是这个连接 : http://www.cnblogs.com/liwenzhou/p/7931828.html 注意: 这节讲的是  母版语言的灵活用法!  可 ...