【后端面试总结】mysql的group by怎么用

GROUP BY 是 SQL 中的一种用于对结果集进行分组的子句,常与聚合函数(如 COUNT()SUM()AVG()MAX()MIN() 等)一起使用。GROUP BY 的作用是基于一个或多个列对查询结果进行分组,然后可以对每个分组执行聚合操作。

以下是 GROUP BY 的一些关键点和用法示例:

基本用法

假设有一个名为 employees 的表,表结构如下:

id name department salary
1 Alice HR 5000
2 Bob IT 6000
3 Carol HR 5500
4 David IT 6200
5 Eve Sales 5800
示例 1: 按部门统计员工人数
sql 复制代码
SELECT department, COUNT(*) AS number_of_employees
FROM employees
GROUP BY department;

这条查询会返回每个部门的员工人数。

示例 2: 按部门计算平均薪资
sql 复制代码
SELECT department, AVG(salary) AS average_salary
FROM employees
GROUP BY department;

这条查询会返回每个部门的平均薪资。

使用多个列分组

你也可以按多个列进行分组。例如,如果你想按部门和薪资等级对员工进行分组,可以这样做:

sql 复制代码
SELECT department, salary, COUNT(*) AS number_of_employees
FROM employees
GROUP BY department, salary;

注意事项

  1. SELECT 列表中的所有列 : 在 SELECT 语句中,GROUP BY 的影响是所有未参与聚合的列都应出现在 GROUP BY 子句中。

  2. NULL 处理 : 当分组键中存在 NULL 值时,SQL 会将 NULL 值单独作为一个分组。

  3. HAVING 子句 : 可以在 GROUP BY 的结果上使用 HAVING 子句进行过滤。HAVING 子句的作用类似于 WHERE 子句,但 WHERE 是在分组之前过滤记录,而 HAVING 是在分组之后过滤结果。

    示例:

    sql 复制代码
    SELECT department, AVG(salary) AS average_salary
    FROM employees
    GROUP BY department
    HAVING AVG(salary) > 5500;

    这条查询返回平均薪资大于 5500 的部门。

  4. 顺序 : GROUP BY 子句通常出现在 WHERE 子句之后,ORDER BY 子句之前。

通过使用 GROUP BY,你可以对数据进行强大的分组和聚合,帮助你从复杂的数据集中提取有价值的信息。

相关推荐
Lee川1 小时前
从异步迷雾到优雅流程:JavaScript异步编程与内存管理的现代化之旅
javascript·面试
晴殇i3 小时前
揭秘JavaScript中那些“不冒泡”的DOM事件
前端·javascript·面试
绝无仅有4 小时前
Redis过期删除与内存淘汰策略详解
后端·面试·架构
绝无仅有4 小时前
Redis大Key问题排查与解决方案全解析
后端·面试·架构
AAA梅狸猫5 小时前
Looper.loop() 循环机制
面试
AAA梅狸猫5 小时前
Handler基本概念
面试
Wect5 小时前
浏览器缓存机制
前端·面试·浏览器
掘金安东尼6 小时前
Fun with TypeScript Generics:玩转 TS 泛型
前端·javascript·面试
掘金安东尼6 小时前
Next.js 企业级落地
前端·javascript·面试
掘金安东尼6 小时前
React 性能优化完全指南 2026
前端·javascript·面试