mysql之过滤分组

在MySQL中,过滤分组数据通常使用 GROUP BY 结合 HAVING 子句和 WHERE 子句。GROUP BY 子句用于将结果集按一个或多个列进行分组,而 HAVING 子句用于过滤分组后的数据。WHERE 子句用于过滤分组前的数据。下面是具体的用法和示例:

GROUP BY 子句

GROUP BY 子句用于根据一个或多个列对结果集进行分组。通常结合聚合函数(如 COUNTSUMAVGMAXMIN)使用。

基本语法
sql 复制代码
SELECT column1, column2, aggregate_function(column3)
FROM table_name
WHERE condition
GROUP BY column1, column2
ORDER BY column1, column2;

示例

  1. 按部门分组统计员工人数
sql 复制代码
SELECT department_id, COUNT(*) AS employee_count
FROM employees
GROUP BY department_id;

HAVING 子句

HAVING 子句用于过滤分组后的数据。它的作用类似于 WHERE 子句,但 WHERE 子句是在分组前过滤记录,而 HAVING 子句是在分组后过滤记录。

基本语法
sql 复制代码
SELECT column1, column2, aggregate_function(column3)
FROM table_name
WHERE condition
GROUP BY column1, column2
HAVING aggregate_function(column3) condition
ORDER BY column1, column2;

示例

  1. 按部门分组统计员工人数,并只显示员工人数超过5人的部门
sql 复制代码
SELECT department_id, COUNT(*) AS employee_count
FROM employees
GROUP BY department_id
HAVING COUNT(*) > 5;
  1. 按部门分组统计员工平均工资,并只显示平均工资高于5000的部门
sql 复制代码
SELECT department_id, AVG(salary) AS average_salary
FROM employees
GROUP BY department_id
HAVING AVG(salary) > 5000;

结合 WHEREHAVING

WHERE 子句和 HAVING 子句可以一起使用,WHERE 子句用于过滤原始数据,HAVING 子句用于过滤分组后的数据。

示例
  1. 在计算平均工资前过滤掉工资低于3000的员工,并按部门分组统计员工平均工资,只显示平均工资高于5000的部门
sql 复制代码
SELECT department_id, AVG(salary) AS average_salary
FROM employees
WHERE salary >= 3000
GROUP BY department_id
HAVING AVG(salary) > 5000;

复杂示例

以下是一个更复杂的示例,展示了如何结合使用 GROUP BYHAVING 和聚合函数来进行数据分析:

  1. 统计每个部门的员工人数、平均工资和最高工资,并只显示员工人数超过10且平均工资高于4000的部门
sql 复制代码
SELECT department_id,
       COUNT(*) AS employee_count,
       AVG(salary) AS average_salary,
       MAX(salary) AS max_salary
FROM employees
GROUP BY department_id
HAVING COUNT(*) > 10 AND AVG(salary) > 4000;

注意事项

  • WHEREHAVING 的区别WHERE 用于过滤原始数据行,HAVING 用于过滤分组后的数据行。
  • 使用聚合函数HAVING 子句通常用于包含聚合函数的条件过滤。
  • 性能考虑 :在大型数据集上,尽量先使用 WHERE 子句进行初步过滤,以减少分组和聚合的数据量,从而提高查询性能。
相关推荐
正在走向自律19 小时前
金仓数据库KingbaseES中级语法详解与实践指南
数据库·oracle·kingbasees·金仓数据库·信创改造
Gofarlic_oms119 小时前
Windchill用户登录与模块访问失败问题排查与许可证诊断
大数据·运维·网络·数据库·人工智能
我是小疯子6619 小时前
Python变量赋值陷阱:浅拷贝VS深拷贝
java·服务器·数据库
Zoey的笔记本20 小时前
2026告别僵化工作流:支持自定义字段的看板工具选型与部署指南
大数据·前端·数据库
静听山水20 小时前
docker安装starrocks
数据库
学编程的小程21 小时前
从“兼容”到“超越”:金仓KESBSON引擎如何借多模融合改写文档数据库规则
数据库
千层冷面21 小时前
数据库分库分表
java·数据库·mysql·oracle
DBA小马哥21 小时前
金仓数据库引领国产化替代新范式:构建高效、安全的文档型数据库迁移解决方案
数据库·安全·mongodb·dba·迁移学习
企业对冲系统官1 天前
基差风险管理系统日志分析功能的架构与实现
大数据·网络·数据库·算法·github·动态规划
冉冰学姐1 天前
SSM学毕电设信息采集系统74v6w(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·学生管理·ssm 框架应用·学毕电设·信息采集系统