前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL | 分组查询的应用

MySQL | 分组查询的应用

作者头像
Zkeq
发布2022-05-18 15:27:59
4K0
发布2022-05-18 15:27:59
举报
文章被收录于专栏:ZkeqZkeq

数据操作语言:分组查询

为什么要分组?
  • 默认情况下汇总函数是对全表范围内的数据做统计
  • GROUP BY 子句的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对每个小区域分别进行数据汇总处理
代码语言:javascript
复制
SELECT deptno,AVG(sal) FROM t_emp
GROUP BY deptno;

代码语言:javascript
复制
SELECT deptno,ROUND(AVG(sal)) FROM t_emp
GROUP BY deptno;
-- ROUND 取整

逐级分组
  • 数据库支持多列分组条件,执行的时候逐级分组。
  • 查询每个部分里,每种职位的人员数量和平均底薪
代码语言:javascript
复制
SELECT deptno,job,COUNT(*),AVG(sal)
FROM t_emp GROUP BY deptno,job
ORDER BY deptno;

代码语言:javascript
复制
SELECT deptno,job,COUNT(*),AVG(sal) 
FROM t_emp
GROUP BY deptno,job
ORDER BY deptno

对 SELECT 子句的要求
  • 查询语句中如果含有 GROUP BY 子句,那么 SELECT 子句中的内容就必须要遵守规定:
    • SELECT 子句中可以包含聚合函数,或者 GROUP BY 子句的分组列,其余内容君不可出现在 SELECT 子句中。
代码语言:javascript
复制
SELECT deptno,COUNT(*),AVG(sal)
FROM t_emp GROUP BY deptno;

代码语言:javascript
复制
SELECT dept_no,COUNT(*),AVG(sal),sal
FROM t_emp GROUP BY deptno;
-- XXXXXXXXXXXXXX

查看规则校验
代码语言:javascript
复制
SELECT @@GLOBAL.sql_mode;
SELECT @@SESSION.sql_mode;

对分组结果集再次做汇总计算
代码语言:javascript
复制
SELECT
	deptno,COUNT(*),AVG(sal),MAX(sal),MIN(sal)
FROM t_emp GROUP BY deptno WITH ROLLUP
-- WITH ROLLUP 汇总

01
01
代码语言:javascript
复制
SELECT deptno,AVG(sal),SUM(sal),MAX(sal),MIN(sal),count(*)
FROM t_emp
GROUP BY deptno WITH ROLLUP

GROUP_CONCAT 函数
  • GROUP_CONCAT 函数可以把分组查询中的某个字段拼接成一个字符串
  • 查询每个部门内底薪超过2000元的人数和员工命令
代码语言:javascript
复制
SELECT deptno,GROUP_CONCAT(ename),COUNT(*)
FROM t_emp WHERE sal>=2000
GROUP BY deptno;

代码语言:javascript
复制
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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-04-27,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 为什么要分组?
  • 逐级分组
  • 对 SELECT 子句的要求
    • 查看规则校验
    • 对分组结果集再次做汇总计算
    • GROUP_CONCAT 函数
    • 各种子句的执行顺序
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档