数据操作语言:分组查询
GROUP BY
子句的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对每个小区域分别进行数据汇总处理SELECT deptno,AVG(sal) FROM t_emp
GROUP BY deptno;
SELECT deptno,ROUND(AVG(sal)) FROM t_emp
GROUP BY deptno;
-- ROUND 取整
SELECT deptno,job,COUNT(*),AVG(sal)
FROM t_emp GROUP BY deptno,job
ORDER BY deptno;
SELECT deptno,job,COUNT(*),AVG(sal)
FROM t_emp
GROUP BY deptno,job
ORDER BY deptno
GROUP BY
子句,那么 SELECT
子句中的内容就必须要遵守规定:SELECT
子句中可以包含聚合函数,或者 GROUP BY
子句的分组列,其余内容君不可出现在 SELECT
子句中。SELECT deptno,COUNT(*),AVG(sal)
FROM t_emp GROUP BY deptno;
SELECT dept_no,COUNT(*),AVG(sal),sal
FROM t_emp GROUP BY deptno;
-- XXXXXXXXXXXXXX
SELECT @@GLOBAL.sql_mode;
SELECT @@SESSION.sql_mode;
SELECT
deptno,COUNT(*),AVG(sal),MAX(sal),MIN(sal)
FROM t_emp GROUP BY deptno WITH ROLLUP
-- WITH ROLLUP 汇总
SELECT deptno,AVG(sal),SUM(sal),MAX(sal),MIN(sal),count(*)
FROM t_emp
GROUP BY deptno WITH ROLLUP
GROUP_CONCAT
函数可以把分组查询中的某个字段拼接成一个字符串SELECT deptno,GROUP_CONCAT(ename),COUNT(*)
FROM t_emp WHERE sal>=2000
GROUP BY deptno;
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