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

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










