SQL关键字快速入门:HAVING 分组后的条件过滤

在前面的文章中,我们已经学习了如何使用 GROUP BY 对数据进行分组统计。例如计算每个用户的订单总金额、每种产品的销售数量等。

但有时候我们并不需要所有的分组结果,而是只想保留某些符合条件的组 。这时候就要用到另一个非常重要的关键字 ------ HAVING


一、什么是 HAVING?

HAVING 是 SQL 中用于对 GROUP BY 分组后的结果进行条件过滤的关键字。

你可以把它理解为:"只留下满足我条件的数据组"。

⚠️ 注意:WHERE 是在分组前过滤原始数据;而 HAVING 是在分组后对聚合结果进行过滤。


二、基本语法

sql 复制代码
SELECT column1, aggregate_function(column2)
FROM table_name
GROUP BY column1
HAVING condition;
  • condition:是一个基于聚合函数的条件表达式。

四、示例讲解

假设我们有一个 orders 表,记录了用户购买的商品和金额:

表:orders

order_id user_id product amount
1 1 手机 2999
2 1 耳机 499
3 2 鼠标 199
4 2 键盘 399
5 3 显示器 899

示例1:筛选出订单总额大于 1000 的用户

sql 复制代码
SELECT user_id, SUM(amount) AS total_amount
FROM orders
GROUP BY user_id
HAVING total_amount > 1000;

结果:

user_id total_amount
1 3498

只有张三的总金额超过了1000元,所以他是唯一一个被保留的结果。


示例2:筛选出订单数大于等于 2 的用户

sql 复制代码
SELECT user_id, COUNT(*) AS order_count
FROM orders
GROUP BY user_id
HAVING order_count >= 2;

结果:

user_id order_count
1 2
2 2

这两个用户各下了至少两个订单。


示例3:结合 WHERE 和 HAVING 使用

sql 复制代码
-- 先筛选出金额大于 200 的订单,再按用户分组并筛选出总金额大于 500 的用户
SELECT user_id, SUM(amount) AS total
FROM orders
WHERE amount > 200
GROUP BY user_id
HAVING total > 500;

结果:

user_id total
1 3498
2 598
3 899

这里先通过 WHERE 筛选掉小于200元的订单,再进行分组统计,并最终保留总金额超过500元的用户。


注意

对比项 WHERE HAVING
作用时机 在分组前过滤原始数据 在分组后过滤聚合结果
支持字段 原始表中的列 聚合函数或别名
是否必须配合 GROUP BY 使用

四、总结对比表

场景 使用方式
分组后筛选总金额大于 X HAVING SUM(amount) > X
分组后筛选订单数量 HAVING COUNT(*) >= N
分组后筛选平均值 HAVING AVG(score) > 80
分组后筛选最大/最小值 HAVING MAX(value) > 1000
分组后筛选特定聚合结果 HAVING MIN(price) < 50

如果这篇文章对大家有帮助可以点赞关注,你的支持就是我的动力😊!

相关推荐
数据组小组4 小时前
免费数据库管理工具深度横评:NineData 社区版、Bytebase 社区版、Archery,2026 年开发者该选哪个?
数据库·测试·数据库管理工具·数据复制·迁移工具·ninedata社区版·naivicat平替
爱可生开源社区6 小时前
MiniMax M2.5 的 SQL 能力令人惊艳!
sql·llm
用户8307196840829 小时前
MySQL 查询优化 30 条封神技巧:用好索引,少耗资源,查询快到飞起
mysql
Nyarlathotep011310 小时前
事务隔离级别
sql·mysql
悟空聊架构10 小时前
基于KaiwuDB在游乐场“刷卡+投币”双模消费系统中的落地实践
数据库·后端·架构
IvorySQL11 小时前
PostgreSQL 技术日报 (3月4日)|硬核干货 + 内核暗流一网打尽
数据库·postgresql·开源
Nyarlathotep011313 小时前
SQL的事务控制
sql·mysql
进击的丸子14 小时前
虹软人脸服务器版SDK(Linux/ARM Pro)多线程调用及性能优化
linux·数据库·后端
用户861782773651814 小时前
MySQL 8.0从库宕机排查实录:中继日志膨胀引发的连锁故障复盘
mysql
NineData1 天前
NineData智能数据管理平台新功能发布|2026年1-2月
数据库·sql·数据分析