having 子句用于在 sql 查询中对分组数据进行过滤,与 where 子句对单个行进行过滤不同,having 子句用于对由 group by 子句创建的组进行过滤。用途包括:过滤基于组的汇总值、应用聚合函数条件和过滤满足特定条件的组。
SQL 中 HAVING 的含义
HAVING 子句用于在 SQL 查询中 对分组数据进行过滤。与 WHERE 子句对单个行进行过滤不同,HAVING 子句用于对由 GROUP BY 子句创建的组进行过滤。
语法
SELECT <column_list>
FROM <table_name>
GROUP BY <column_name>
HAVING <filter_condition>;</filter_condition></column_name></table_name></column_list>
用途
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 子句在分组之后应用条件。