Mysql group by 用法

GROUP BY 是 SQL 中一个非常重要的子句,主要用于结合聚合函数对数据进行分组统计和分析。下面为你详细介绍它的作用和用法。

作用

GROUP BY 子句的核心作用是将查询结果按照指定的列或表达式进行分组。分组后,数据库会将相同值的行归为一组,然后可以对每个组应用聚合函数,如 SUM()COUNT()AVG()MIN()MAX() 等,从而得到每个组的汇总信息。这样可以方便地对数据进行统计和分析,例如统计每个部门的员工数量、每个产品的销售总额等。

1. 简单分组统计

假设有一个 employees 表,包含 department_id(部门编号)和 salary(工资)两列,我们可以使用 GROUP BY 统计每个部门的员工数量:

sql 复制代码
SELECT department_id, COUNT(*) AS employee_count
FROM employees
GROUP BY department_id;
2. 结合其他聚合函数

同样使用 employees 表,我们可以统计每个部门的平均工资:

sql 复制代码
SELECT department_id, AVG(salary) AS average_salary
FROM employees
GROUP BY department_id;
3. 按多个列分组

如果 employees 表还有 job_title(职位名称)列,我们可以按部门和职位分组,统计每个部门每个职位的员工数量:

sql 复制代码
SELECT department_id, job_title, COUNT(*) AS employee_count
FROM employees
GROUP BY department_id, job_title;

解释

  • GROUP BY department_id, job_title:按照 department_idjob_title 两列进行分组,将 department_idjob_title 都相同的记录归为一组

WHEREHAVING 子句结合使用

1. 与 WHERE 子句结合

WHERE 子句用于在分组之前筛选记录。例如,我们只统计工资大于 5000 的员工所在部门的员工数量:

sql 复制代码
SELECT department_id, COUNT(*) AS employee_count
FROM employees
WHERE salary > 5000
GROUP BY department_id;
  • 解释
    • WHERE salary > 5000:在分组之前筛选出 salary 大于 5000 的记录,然后再进行分组统计。
2. 与 HAVING 子句结合

HAVING 子句用于在分组之后筛选分组结果。例如,我们只显示员工数量大于 10 的部门:

sql 复制代码
SELECT department_id, COUNT(*) AS employee_count
FROM employees
GROUP BY department_id
HAVING employee_count > 10;
  • 解释
    • HAVING employee_count > 10:在分组统计完成后,筛选出 employee_count 大于 10 的分组。

注意事项

  • SELECT 语句中,除了聚合函数,其他列必须出现在 GROUP BY 子句中。例如:

    sql 复制代码
    -- 错误示例
    SELECT department_id, salary
    FROM employees
    GROUP BY department_id;

    上述示例中,salary 列既不是聚合函数的参数,也不在 GROUP BY 子句中,会导致语法错误。

  • GROUP BY 子句通常在 WHERE 子句之后、ORDER BY 子句之前使用。其执行顺序一般为:FROM -> WHERE -> GROUP BY -> HAVING -> SELECT -> ORDER BY

通过合理使用 GROUP BY 子句,可以对数据库中的数据进行有效的分组统计和分析,从而提取出有价值的信息。

相关推荐
像风一样!35 分钟前
MySQL Galera Cluster部署如何实现负载均衡和高可用
数据库·mysql
last_zhiyin2 小时前
Oracle sql tuning guide 翻译 Part 6-4 --- Hint使用准则和Hint使用报告
数据库·sql·oracle·sql tunning
chenchihwen2 小时前
AI代码开发宝库系列:FAISS向量数据库
数据库·人工智能·python·faiss·1024程序员节
小光学长3 小时前
基于Vue的课程达成度分析系统t84pzgwk(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
摇滚侠3 小时前
全面掌握PostgreSQL关系型数据库,备份和恢复,笔记46和笔记47
java·数据库·笔记·postgresql·1024程序员节
周杰伦fans4 小时前
Navicat - 连接 mysql 、 sqlserver 数据库 步骤与问题解决
数据库·mysql·sqlserver
csdn_aspnet4 小时前
如何在 Ubuntu 24.04/22.04/20.04 上安装 MySQL 8.0
linux·mysql·ubuntu
码以致用4 小时前
StarRocks笔记
数据库·starrocks·olap·1024程序员节
auspicious航5 小时前
PostgreSQL数据库关于pg_rewind的认识
数据库·postgresql·oracle
最好结果5 小时前
MyBatis 精确查询逗号分隔字符串
mysql·mybatis·1024程序员节