转载自:https://blog.csdn.net/xx_star1204/article/details/72884983

在平时的开发任务中我们经常会用到MYSQL的GROUP BY分组, 用来获取数据表中以分组字段为依据的统计数据。比如有一个学生选课表,表结构如下:

Table: Subject_Selection

Subject Semester Count
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。

最新文章

  1. 后台程序员的HTTP缓存
  2. (2) 深入理解Java Class文件格式(一)
  3. 51nod 1050 循环数组最大子段和
  4. Win7环境下VS2010配置Cocos2d-x-2.1.4最新版本号的开发环境
  5. linux 下 奇怪的 动态库 依赖问题
  6. Super Object Toolkit (支持排序)
  7. 删除织梦所有待审核稿件sql语句
  8. Windows下虚拟Linux
  9. uva 10929 - You can say 11
  10. JavaScript正则表达式模式匹配(5)——特殊字符匹配、换行模式
  11. EBS-子库存转移和物料搬运单区别
  12. vue + elementUi + upLoadIamge组件 上传文件到阿里云oss
  13. Windows 10 IoT Core 17101 for Insider 版本更新
  14. jsp笔记----97DatePicker日期插件简单使用
  15. [转] 如何轻松愉快地理解条件随机场(CRF)?
  16. cdqz2017-test11-奇诺之旅(拟阵)
  17. 浅析C#中的托付
  18. ctags简易用法
  19. [UE4]C++方法多个返回值给蓝图
  20. IE各浏览器HACK

热门文章

  1. android 第三方开源库 学习汇总之Butter Knife
  2. Mysql-5.5版本搭建实例的部分库的从库
  3. OGG 源端与目标端 约束不一致
  4. linux常见性能分析工具
  5. DDL(数据库定义语言)(五)
  6. Transformer---BERT模型
  7. LOJ 3120: 洛谷 P5401: 「CTS2019 | CTSC2019」珍珠
  8. Word 2016中公式不能自动斜体的解决方法
  9. windows下apache + mod_wsgi + python部署flask接口服务
  10. wordpress怎么用AMP加速器呢