Skip to main content

Command Palette

Search for a command to run...

MySQL | 分组查询的应用

Published
1 min read
MySQL | 分组查询的应用

数据操作语言:分组查询

为什么要分组?

  • 默认情况下汇总函数是对全表范围内的数据做统计
  • 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

对 SELECT 子句的要求

  • 查询语句中如果含有 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 汇总

01

SELECT deptno,AVG(sal),SUM(sal),MAX(sal),MIN(sal),count(*)
FROM t_emp
GROUP BY deptno WITH ROLLUP

GROUP_CONCAT 函数

  • GROUP_CONCAT 函数可以把分组查询中的某个字段拼接成一个字符串

  • 查询每个部门内底薪超过2000元的人数和员工命令

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

10 views

More from this blog

MySQL | 表的内连接

数据操作语言:表连接查询(一) 从多张表中提取数据 从多张表提取数据,必须指定关联的条件。如果不定义关联条件就会出现无条件连接,两张表的数据会交叉连接,产生 笛卡尔积。 规定了连接条件的表连接语句,就不会出现笛卡尔积。 # 查询每名员工的部门信息 SELECT e.empno,e.ename,d.dname FROM t_emp e JOIN t_dept d ON e.deptno=d.deptno; 表连接的分类 表连接分为两种:内连接 和 外连接 内连接是结果集中只保留符合...

May 16, 20221 min read13
MySQL | 表的内连接

MySQL | 聚合函数的使用

数据操作语言:聚合函数 什么是聚合函数 聚合函数在数据的查询分析中,应用十分广泛。聚合函数可以对 数据求和、求 最大值 和 最小值 、求 平均值 等等。 求公司员工的评价月收入是多少? SELECT AVG(sal+IFNULL(comm,0)) FROM t_emp; SELECT AVG(sal+IFNULL(comm,0)) AS avg FROM t_emp; SUM 函数 SUM 函数用于求和,只能用户数字类型,字符类型的统计结果为 0 ,日期类型统计结果是毫秒数相加 SE...

Apr 26, 20221 min read8
MySQL | 聚合函数的使用
U

Untitled Publication

173 posts