mysql "order by" "distinct" "group by" "having"
本文用到的表结构
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"的更多相关文章
- mysql中函数DISTINCT,group by,CONCAT及GROUP_CONCAT的使用
一:DISTINCT 在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供有distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是 ...
- mysql distinct&group by 应用
在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供 有distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记录的 ...
- mysql 中order by 与group by的顺序
mysql 中order by 与group by的顺序 是: select from where group by order by 注意:group by 比order by先执行,order b ...
- mysql 去除重复 Select中DISTINCT关键字的用法 在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供 有distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记录的所有值。其原因是 distinct只能返回它的目标字段,而无法返回其它字段,这个问题让我困扰了很久,用distinct不能解决的话,
在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供 有distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记 ...
- ORDER BY,GROUP BY 和DI STI NCT 优化
读<MySQL性能调优与架构设计>笔记之ORDER BY,GROUP BY 和DI STI NCT 优化 2015年01月18日 18:51:31 lihuayong 阅读数:2593 标 ...
- 转 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 ...
- mysql中select distinct的用法
在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供有distinct这个关键字来过滤掉多余的重复记录只保留一条,但 往往只用它来返回不重复记录的条数,而不是用它来返回不重记录的 ...
- Hive中笔记 :三种去重方法,distinct,group by与ROW_Number()窗口函数
一.distinct,group by与ROW_Number()窗口函数使用方法 1. Distinct用法:对select 后面所有字段去重,并不能只对一列去重. (1)当distinct应用到多个 ...
- mysql中去重 distinct 用法
在使用MySQL时,有时需要查询出某个字段不重复的记录,这时可以使用mysql提供的distinct这个关键字来过滤重复的记录,但是实际中我们往往用distinct来返回不重复字段的条数(count( ...
随机推荐
- 如何在浏览器中简单模拟微信浏览器(仅限于通过User Agent进行判断的页面)
模拟微信浏览器: .打开360极速 .F12开发者工具 .开发者模式左上方有一个手机样子的图标 点击进入 设备模式‘ .将UA选项中的字符串替换成: Mozilla/ 备注: 替换的字符串是微信浏览器 ...
- 使用Phoenix通过sql语句更新操作hbase数据
hbase 提供很方便的shell脚本,可以对数据表进行 CURD 操作,但是毕竟是有一定的学习成本的,基本上对于开发来讲,sql 语句都是看家本领,那么,有没有一种方法可以把 sql 语句转换成 h ...
- Qt获取CPU编号和硬盘序列号
windows下执行命令除了用cmd之外,还有个东西叫WMIC,非常强大,可以通过他获取很多信息,包括硬件信息. QString frmMain::getWMIC(const QString & ...
- jQuery缓存机制(三)
缓存机制提供的入口有: $.data([key],[value]) // 存取数据 $.hasData(elem) // 是否有数据 $.removeData([key]) // 删除数据 $.acc ...
- 关于 ArrayList.toArray() 和 Arrays.asList().toArray()方法
1.ArrayList.toArray() 理解 * 通过源码我们可以看到返回的是Object类型的数组,失去了原有的实际类型,虽然底层存储是具体类型的对象,这也正体现了文档中说的:该方法起到了 ...
- VI 你不知道的事
1G 顶部 G 底部 ctrl+F 前进 ctrl+B 后退 /text 向前搜索 ?text 向后搜索 I i 插入字符串 a 光标后插入字符 A 跳到句末尾 wq 写入并退出 h k j l ...
- 深入浅出WPF之Binding的使用(一)
在WPF中Binding可以比作数据的桥梁,桥梁的两端分别是Binding的源(Source)和目标(Target).一般情况下,Binding源是逻辑层对象,Binding目标是UI层的控件对象:这 ...
- Css控制网页变灰
兼容IE chrome Firefox..... html{ filter:grayscale(%); -moz-filter:grayscale(%); -o-filter:grayscale(%) ...
- background-size:100% 100% 时 background-position: % 失效
背景知识: background-size background-position 难题: background-size 为 100% 100% 时,background-position 部分失效 ...
- 170821、本地代码上传gitlub
第一步:建立git仓库 cd到你的本地项目根目录下,执行git命令 git init #初始化项目 第二步:将项目的所有文件添加到仓库中 git add . 或者git add -A #如果想添加某个 ...