HAVING 子句用于在 SQL 查询中对分组数据进行过滤,与 WHERE 子句对单个行进行过滤不同,HAVING 子句用于对由 GROUP BY 子句创建的组进行过滤。用途包括:过滤基于组的汇总值、应用聚合函数条件和过滤满足特定条件的组。
SQL 中 HAVING 的含义

语法
SELECTFROM GROUP BY HAVING ;
用途
HAVING 子句通常用于以下场景:
- 基于组的汇总值进行过滤。
- 在聚合函数(例如 SUM、COUNT、AVG 等)的结果上应用条件。
- 过滤出满足特定条件的组。
示例
以下查询使用 HAVING 子句过滤出销售额超过 1000 美元的部门:
SELECT department_id, SUM(sales) AS total_sales FROM sales GROUP BY department_id HAVING total_sales > 1000;
在这个查询中:
-
department_id列用于对数据进行分组。 -
SUM(sales)聚合函数计算每个部门的总销售额。 -
HAVING total_sales > 1000条件过滤出总销售额超过 1000 美元的部门。
where和having的区别
WHERE 子句用于过滤单个行,而在 HAVING 子句用于过滤组。此外,WHERE 子句在进行分组之前应用条件,而 HAVING 子句在分组之后应用条件。








