MySQL聚合函数

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: MySQL聚合函数

聚合函数

GROUP BY分组

按照department_id分组,查询department_id和该分组中员工的平均工资

SELECT department_id, AVG(salary)
FROM employees
GROUP BY department_id;

按照相同的department_id和job_id分组,查询分组中员工的平均工资和其他信息

SELECT department_id, job_id, AVG(salary)
FROM employees
GROUP BY department_id, job_id;

GROUP BY中使用WITH ROLLUP

使用 WITH ROLLUP 关键字之后,在所有查询出的分组记录之后增加一条记录,该记录计算查询出的所有记录的总和,即统计记录数量。

SELECT department_id, AVG(salary)
FROM employees
GROUP BY department_id
WITH ROLLUP;

注意:当使用ROLLUP时,不能同时使用ORDER BY子句进行结果排序,即ROLLUP和ORDER BY是互相排斥的

SELECT department_id, AVG(salary)
FROM employees
GROUP BY department_id
WHERE department_id > 80
WITH ROLLUP;# 报错

HAVING

当使用聚合函数时(如MAX,AVG),不能使用WHERE来设置条件。

非法使用聚合函数 :

SELECT department_id, AVG(salary)
FROM employees
GROUP BY department_id
WHERE department_id > 80;# 报错

我们应该使用HAVING来设置条件

SELECT department_id, AVG(salary)
FROM employees
GROUP BY department_id
HAVING department_id > 80;

并且,HAVING应该只在有GROUP BY的语句中使用(尽管不会报错)

查询部门为10,20,30,40中最高工资比1w高的部门信息:

SELECT d.department_id, department_name, d.location_id, MAX(salary)
FROM employees e
JOIN departments d
ON e.department_id = d.department_id
WHERE d.department_id IN (10,20,30,40)
GROUP BY department_id
HAVING MAX(salary) > 10000;

WHERE与HAVING对比:

优点 缺点
WHERE 先筛选数据再关联,执行效率高 不能使用分组中的计算函数进行筛选
HAVING 可以使用分组中的计算函数 在最后的结果集中进行筛选,执行效率较低

开发中的选择:
WHERE 和 HAVING 也不是互相排斥的,我们可以在一个查询里面同时使用 WHERE 和 HAVING。包含分组统计函数的条件用 HAVING,普通条件用 WHERE。这样,我们就既利用了 WHERE 条件的高效快速,又发挥了 HAVING 可以使用包含分组统计函数的查询条件的优点。当数据量特别大的时候,运行效率会有很大的差别。

SELECT底层逻辑

查询的结构

#方式1:
SELECT ...,....,...
FROM ...,...,....
WHERE 多表的连接条件
AND 不包含组函数的过滤条件
GROUP BY ...,...
HAVING 包含组函数的过滤条件
ORDER BY ... ASC/DESC
LIMIT ...,...
#方式2:
SELECT ...,....,...
FROM ... JOIN ...
ON 多表的连接条件
JOIN ...
ON ...
WHERE 不包含组函数的过滤条件
AND/OR 不包含组函数的过滤条件
GROUP BY ...,...
HAVING 包含组函数的过滤条件
ORDER BY ... ASC/DESC
LIMIT ...,...
#其中:
#(1)from:从哪些表中筛选
#(2)on:关联多表查询时,去除笛卡尔积
#(3)where:从表中筛选的条件
#(4)group by:分组依据
#(5)having:在统计结果中再次筛选
#(6)order by:排序
#(7)limit:分页

image-20230117175638062

SQL语句的执行过程

image-20230117180549822

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
SQL 关系型数据库 MySQL
mysql子查询、聚合函数
mysql子查询、聚合函数
|
1月前
|
关系型数据库 MySQL 数据挖掘
轻松入门MySQL:深入理解MySQL聚合函数,实战进销存项目中的应用与技巧(8)
轻松入门MySQL:深入理解MySQL聚合函数,实战进销存项目中的应用与技巧(8)
|
4月前
|
关系型数据库 MySQL 数据库
MySQL查询聚合函数与分组查询
MySQL查询聚合函数与分组查询
|
12天前
|
SQL 关系型数据库 MySQL
【MySQL】DQL-聚合函数介绍&常见聚合函数&语法&注意事项&可cv例题语句
【MySQL】DQL-聚合函数介绍&常见聚合函数&语法&注意事项&可cv例题语句
|
8月前
|
关系型数据库 MySQL BI
MySQL数据库操作篇3(聚合函数&分组查询)
MySQL数据库操作篇3(聚合函数&分组查询)
93 0
|
9月前
|
关系型数据库 MySQL
[MySQL]聚合函数与分组(三)
[MySQL]聚合函数与分组(三)
[MySQL]聚合函数与分组(三)
|
5月前
|
SQL 关系型数据库 MySQL
Mysql数据库 5.SQL语言聚合函数 语言日期-字符串函数
Mysql数据库 5.SQL语言聚合函数 语言日期-字符串函数
43 0
|
6月前
|
关系型数据库 MySQL
mysql聚合函数
mysql聚合函数
40 0
|
9月前
|
SQL 关系型数据库 MySQL
[MySQL]聚合函数与分组(二)
[MySQL]聚合函数与分组(二)
|
9月前
|
存储 关系型数据库 MySQL