数据操作语言:分组查询
为什么要分组?
- 默认情况下汇总函数是对全表范围内的数据做统计
GROUP BY
子句的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对每个小区域分别进行数据汇总处理
1 2
| SELECT deptno,AVG(sal) FROM t_emp GROUP BY deptno;
|
1 2 3
| SELECT deptno,ROUND(AVG(sal)) FROM t_emp GROUP BY deptno;
|
逐级分组
- 数据库支持多列分组条件,执行的时候逐级分组。
- 查询每个部分里,每种职位的人员数量和平均底薪
1 2 3
| SELECT deptno,job,COUNT(*),AVG(sal) FROM t_emp GROUP BY deptno,job ORDER BY deptno;
|
1 2 3 4
| SELECT deptno,job,COUNT(*),AVG(sal) FROM t_emp GROUP BY deptno,job ORDER BY deptno
|
对 SELECT 子句的要求
- 查询语句中如果含有
GROUP BY
子句,那么 SELECT
子句中的内容就必须要遵守规定:
SELECT
子句中可以包含聚合函数,或者 GROUP BY
子句的分组列,其余内容君不可出现在 SELECT
子句中。
1 2
| SELECT deptno,COUNT(*),AVG(sal) FROM t_emp GROUP BY deptno;
|
1 2 3
| SELECT dept_no,COUNT(*),AVG(sal),sal FROM t_emp GROUP BY deptno;
|
查看规则校验
1 2
| SELECT @@GLOBAL.sql_mode; SELECT @@SESSION.sql_mode;
|
对分组结果集再次做汇总计算
1 2 3 4
| SELECT deptno,COUNT(*),AVG(sal),MAX(sal),MIN(sal) FROM t_emp GROUP BY deptno WITH ROLLUP
|

1 2 3
| SELECT deptno,AVG(sal),SUM(sal),MAX(sal),MIN(sal),count(*) FROM t_emp GROUP BY deptno WITH ROLLUP
|
GROUP_CONCAT 函数
1 2 3
| SELECT deptno,GROUP_CONCAT(ename),COUNT(*) FROM t_emp WHERE sal>=2000 GROUP BY deptno;
|
1 2 3 4
| SELECT deptno,COUNT(*),GROUP_CONCAT(ename) FROM t_emp WHERE sal>=2000 GROUP BY deptno;
|
各种子句的执行顺序
- 查询语句中,
GROUP BY
子句应该被 第几个执行?
FROM
-> WHERE
-> GROUP BY
-> SELECT
-> ORDER BY
-> LIMIT