Mysql group by原理 having
2017-01-13 22:21
225 查看
在平时的开发任务中我们经常会用到MYSQL的GROUP BY分组, 用来获取数据表中以分组字段为依据的统计数据。比如有一个学生选课表,表结构如下:
我们想统计每门课程有多少个学生报名,应用如下SQL:
得到如下结果:
因为表里记录了有5个学生选择ITB001,2个学生选择了MKB114。
产生这个结果的原因是:
GROUP BY X意思是将所有具有相同X字段值的记录放到一个分组里。
那么GROUP BY X, Y呢?
GROUP BY X, Y意思是将所有具有相同X字段值和Y字段值的记录放到一个分组里。
我们下面再接着要求统计出每门学科每个学期有多少人选择,应用如下SQL:
上面SQL的意思是,对Subject_Selection表中的数据进行分组,将具有相同Subject和Semester字段值的记录放到同一个分组里去, 然后对每个分组中的数据应用聚合函数(COUNT,SUM, AVG,etc)。
得到的结果是:
从表中的记录我们可以看出这个分组结果是正确的有3个学生在第一学期选择了ITB001, 2个学生在第二学期选择了ITB001,还有两个学生在第一学期选择了MKB114, 没人在第二学期选择MKB114。
再比如有一个订单表,表中记录了所有支付过的订单
现在我们想统计每个用户在每种商品上总共花了多少钱,执行如下SQL
获得的结果如下:
总结:
在MYSQL中使用GROUP BY对表中的数据进行分组时,
GROUP BY X意思是将所有具有相同X字段值的记录放到一个分组里,
GROUP BY X, Y意思是将所有具有相同X字段值和Y字段值的记录放到一个分组里。
转自:https://segmentfault.com/a/1190000006821331
Table: Subject_Selection Subject Semester Attendee --------------------------------- ITB001 1 John ITB001 1 Bob ITB001 1 Mickey ITB001 2 Jenny ITB001 2 James MKB114 1 John MKB114 1 Erica
我们想统计每门课程有多少个学生报名,应用如下SQL:
SELECT Subject, Count(*) FROM Subject_Selection GROUP BY Subject
得到如下结果:
Subject Count ------------------------------ ITB001 5 MKB114 2
因为表里记录了有5个学生选择ITB001,2个学生选择了MKB114。
产生这个结果的原因是:
GROUP BY X意思是将所有具有相同X字段值的记录放到一个分组里。
那么GROUP BY X, Y呢?
GROUP BY X, Y意思是将所有具有相同X字段值和Y字段值的记录放到一个分组里。
我们下面再接着要求统计出每门学科每个学期有多少人选择,应用如下SQL:
SELECT Subject, Semester, Count(*) FROM Subject_Selection GROUP BY Subject, Semester
上面SQL的意思是,对Subject_Selection表中的数据进行分组,将具有相同Subject和Semester字段值的记录放到同一个分组里去, 然后对每个分组中的数据应用聚合函数(COUNT,SUM, AVG,etc)。
得到的结果是:
Subject Semester Count ------------------------------ ITB001 1 3 ITB001 2 2 MKB114 1 2
从表中的记录我们可以看出这个分组结果是正确的有3个学生在第一学期选择了ITB001, 2个学生在第二学期选择了ITB001,还有两个学生在第一学期选择了MKB114, 没人在第二学期选择MKB114。
再比如有一个订单表,表中记录了所有支付过的订单
Table: Order Product Buyer Spending --------------------------------- PD001 Todd 12.00 PD001 Todd 12.00 PD001 Todd 12.00 PD001 Lily 12.00 PD001 Lily 12.00 PD002 Todd 20.00 PD002 Todd 20.00
现在我们想统计每个用户在每种商品上总共花了多少钱,执行如下SQL
SELECT Product,Buyer, SUM(Spending) FROM Order GROUP BY Product
获得的结果如下:
Product Buyer SUM ------------------------------ PD001 Todd 36.00 PD001 Lily 24.00 PD002 Todd 40.00
总结:
在MYSQL中使用GROUP BY对表中的数据进行分组时,
GROUP BY X意思是将所有具有相同X字段值的记录放到一个分组里,
GROUP BY X, Y意思是将所有具有相同X字段值和Y字段值的记录放到一个分组里。
转自:https://segmentfault.com/a/1190000006821331
相关文章推荐
- 详解MySQL分组查询Group By实现原理(1)
- MySQL实用语句 GROUP BY ... HAVING ...
- 关于MySQL与SQLLite的Group By排序原理的区别
- 21、MySQL-分组查询(GROUP BY)及二次筛选(HAVING)
- 关于MySQL与SQLLite的Group By排序原理的差别
- MySQL 中 GROUP BY 基本实现原理
- mysql中的Group by与having理解
- Mysql 简单的命令语句续-*,as,group by,order by,group by,having,limit;
- MYSQL GROUP BY 和 HAVING 子句
- MySQL中无GROUP BY情况下直接使用HAVING语句的问题探究
- mysql---select的五种子句学习(where、group by、having、order by、limit)
- Mysql中order by、group by、having的区别深入分析
- Mysql中order by、group by、having的区别深入分析
- mysql---select的五种子句学习(where、group by、having、order by、limit)
- mysql中group by与having合用注意事项分享
- MySQL 中 GROUP BY 基本实现原理
- mysql group by 原理
- MySQL学习足迹记录11--分组数据--GROUP BY,HAVING
- MySQL 里面的Where 和Having和Count 和distinct和Group By对比
- Mysql数据分组GROUP BY 和HAVING,与WHERE组合使用