技术文摘
SQL 中 group by 和 having 用法总结
2025-01-15 03:50:04 小编
SQL 中 group by 和 having 用法总结
在 SQL 数据库操作中,group by 和 having 是两个重要且常用的关键字,掌握它们的用法对于数据的查询和分析至关重要。
group by 子句主要用于对查询结果进行分组。它允许我们根据一个或多个列的值将结果集划分为多个组,从而可以对每个组进行聚合操作,比如计算每组的总和、平均值、计数等。例如,在一个存储员工信息的表中,有部门、薪资等字段,若想统计每个部门的员工人数,就可以使用 group by 子句。示例代码如下:
SELECT department, COUNT(*)
FROM employees
GROUP BY department;
上述代码按照 department 字段对员工进行分组,然后统计每个组中的员工数量。通过 group by,我们能够清晰地了解每个部门的员工规模。
having 子句则是用于对分组后的结果进行筛选。与 where 子句不同,where 是在分组之前对单个行进行筛选,而 having 是在分组之后对整个组进行条件过滤。例如,还是在员工表中,在统计每个部门的平均薪资后,只想显示平均薪资大于 8000 的部门。代码如下:
SELECT department, AVG(salary)
FROM employees
GROUP BY department
HAVING AVG(salary) > 8000;
这段代码先按照部门进行分组,计算每个部门的平均薪资,然后通过 having 子句筛选出平均薪资大于 8000 的部门。
需要注意的是,在使用 group by 和 having 时,select 子句中出现的非聚合列必须包含在 group by 子句中。这是因为在分组后,每个组只返回一行结果,非聚合列必须有明确的取值,否则会导致结果不明确。
group by 和 having 是 SQL 中强大的工具,group by 帮助我们将数据按照特定条件分组并进行聚合操作,having 则进一步对分组后的结果进行筛选,使我们能够获取到更有针对性和价值的数据信息,在数据库开发和数据分析工作中发挥着重要作用。
- 数据平台流量回放的最优实践
- 分布式系统的十种必备模式
- 服务网格技术之浅见
- 十五周算法训练营中的普通动态规划:我们一起探讨
- 面试官谈 JVM 三色标记法,我表示这也问?
- 神经网络损失函数探究
- Java 与 Vue 实现导出 Zip 压缩包的前后端技术
- DotNetty:.Net 平台的高性能网络通信框架
- Vercel 发布 AI SDK 及应用模板 助力快速构建 AI 应用
- 前端已消逝?或许才启程
- Springboot3 新特性之异常信息 ProblemDetail 全面解析
- Go1.21 速览:自定义 go.env 文件获支持 但仍存缺陷
- 理解 CSS step 函数中 jump-* 关键词的方法
- 开启 Rust 代码编写之旅
- 五个新颖的数据科学工具与 Python 结合使用价值高