在 PostgreSQL 中使用 `HAVING` 子句

本文涉及的产品
云原生数据库 PolarDB MySQL 版,通用型 2核4GB 50GB
云原生数据库 PolarDB PostgreSQL 版,标准版 2核4GB 50GB
简介: 【8月更文挑战第12天】

在 PostgreSQL 中,HAVING 子句用于对分组后的数据进行筛选。它是 SQL 标准的一部分,与 GROUP BY 子句密切相关。HAVING 子句允许你在执行聚合函数(如 COUNTSUMAVG 等)后进行过滤,这是 WHERE 子句无法做到的,因为 WHERE 子句在数据分组之前进行过滤。以下是关于在 PostgreSQL 中使用 HAVING 子句的详细介绍,包括其定义、用法、示例和注意事项。

一、HAVING 子句的定义

HAVING 子句用于在 GROUP BY 子句将数据分组并计算聚合函数之后对结果集进行过滤。它允许你应用条件来限制分组后的数据行。例如,你可以在计算每个组的平均值后,筛选出平均值高于特定阈值的组。

二、HAVING 子句的基本语法

HAVING 子句的基本语法如下:

SELECT column1, column2, aggregate_function(column3)
FROM table_name
GROUP BY column1, column2
HAVING condition;
  • column1, column2:用于分组的列。
  • aggregate_function(column3):应用于分组的聚合函数(例如 COUNTSUMAVG)。
  • condition:用于过滤分组结果的条件。

三、HAVING 子句的使用示例

  1. 计算部门的平均薪资,并筛选出平均薪资高于 $50,000 的部门
SELECT department_id, AVG(salary) AS avg_salary
FROM employees
GROUP BY department_id
HAVING AVG(salary) > 50000;

这个查询首先计算每个部门的平均薪资,然后使用 HAVING 子句筛选出那些平均薪资高于 $50,000 的部门。

  1. 找出拥有超过 10 名员工的部门
SELECT department_id, COUNT(*) AS num_employees
FROM employees
GROUP BY department_id
HAVING COUNT(*) > 10;

这个查询计算每个部门的员工数量,并使用 HAVING 子句筛选出员工数量超过 10 的部门。

  1. 找出所有销售额超过 1,000,000 的产品类别
SELECT category, SUM(sales) AS total_sales
FROM products
GROUP BY category
HAVING SUM(sales) > 1000000;

这个查询计算每个产品类别的总销售额,然后筛选出销售额超过 1,000,000 的类别。

  1. 筛选出拥有不低于 5 个订单的客户
SELECT customer_id, COUNT(order_id) AS num_orders
FROM orders
GROUP BY customer_id
HAVING COUNT(order_id) >= 5;

这个查询计算每个客户的订单数量,并筛选出拥有 5 个或更多订单的客户。

四、HAVING 子句与 WHERE 子句的区别

  • 使用时机WHERE 子句用于在数据分组之前过滤数据,而 HAVING 子句用于在数据分组和聚合之后进行过滤。
  • 过滤范围WHERE 子句不能使用聚合函数,而 HAVING 子句可以。

例如,下面的查询展示了如何分别使用 WHEREHAVING 子句:

-- 使用 WHERE 子句筛选薪资大于 50,000 的员工,并按部门分组计算每个部门的平均薪资
SELECT department_id, AVG(salary) AS avg_salary
FROM employees
WHERE salary > 50000
GROUP BY department_id;

-- 使用 HAVING 子句筛选每个部门的平均薪资大于 50,000 的部门
SELECT department_id, AVG(salary) AS avg_salary
FROM employees
GROUP BY department_id
HAVING AVG(salary) > 50000;

在第一个查询中,WHERE 子句首先筛选出薪资大于 50,000 的员工,然后按部门分组计算平均薪资。而在第二个查询中,HAVING 子句在按部门分组并计算平均薪资之后,筛选出平均薪资大于 50,000 的部门。

五、HAVING 子句的高级用法

  1. 结合子查询使用 HAVING

    HAVING 子句可以与子查询结合使用,以实现更复杂的筛选条件。例如:

SELECT department_id, AVG(salary) AS avg_salary
FROM employees
GROUP BY department_id
HAVING AVG(salary) > (
    SELECT AVG(salary) FROM employees
);

这个查询选择了那些平均薪资高于公司整体平均薪资的部门。

  1. 使用 HAVING 进行多个条件筛选

HAVING 子句可以结合多个条件进行筛选。例如:

   SELECT department_id, COUNT(*) AS num_employees, AVG(salary) AS avg_salary
   FROM employees
   GROUP BY department_id
   HAVING COUNT(*) > 10 AND AVG(salary) > 50000;

这个查询选择了员工数量超过 10 且平均薪资高于 50,000 的部门。

六、注意事项

  1. 性能影响

    使用 HAVING 子句可能会影响查询性能,尤其是在处理大数据集时。确保在 GROUP BY 子句中选择必要的列,并考虑优化查询。

  2. 逻辑顺序

    了解 SQL 查询的逻辑顺序有助于正确使用 HAVING 子句。查询首先从表中检索数据,然后应用 WHERE 子句进行过滤,再执行 GROUP BYHAVING 子句。

七、总结

HAVING 子句是 PostgreSQL 中一个强大的工具,用于在数据分组和聚合之后进行过滤。它允许你在 GROUP BY 子句计算聚合结果后进行条件筛选,是处理复杂数据分析的必备功能。掌握 HAVING 子句的用法,有助于编写更加高效和灵活的 SQL 查询。在实际应用中,结合 HAVING 子句和其他 SQL 特性,可以更好地满足数据分析和报告的需求。

相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
目录
相关文章
|
SQL 关系型数据库 PostgreSQL
PostgreSQL 10.1 手册_部分 II. SQL 语言_第 14 章 性能提示_14.3. 用显式JOIN子句控制规划器
14.3. 用显式JOIN子句控制规划器 我们可以在一定程度上用显式JOIN语法控制查询规划器。要明白为什么需要它,我们首先需要一些背景知识。 在一个简单的连接查询中,例如: SELECT * FROM a, b, c WHERE a.id = b.id AND b.ref = c.id; 规划器可以自由地按照任何顺序连接给定的表。
1394 0
|
关系型数据库 分布式数据库 PolarDB
|
关系型数据库 分布式数据库 定位技术
PolarDB for PostgreSQL 开源必读手册-VACUUM处理(中)
PolarDB for PostgreSQL 开源必读手册-VACUUM处理
174 0
|
关系型数据库 分布式数据库 PolarDB
《阿里云产品手册2022-2023 版》——PolarDB for PostgreSQL
《阿里云产品手册2022-2023 版》——PolarDB for PostgreSQL
380 0
|
存储 缓存 关系型数据库
|
存储 SQL 并行计算
PolarDB for PostgreSQL 开源必读手册-开源PolarDB for PostgreSQL架构介绍(中)
PolarDB for PostgreSQL 开源必读手册-开源PolarDB for PostgreSQL架构介绍
436 0
|
存储 算法 安全
PolarDB for PostgreSQL 开源必读手册-开源PolarDB for PostgreSQL架构介绍(下)
PolarDB for PostgreSQL 开源必读手册-开源PolarDB for PostgreSQL架构介绍
395 0
|
关系型数据库 分布式数据库 开发工具
|
存储 关系型数据库 Linux
PolarDB for PostgreSQL 开源必读手册-PolarDB安装与配置(下)
PolarDB for PostgreSQL 开源必读手册-PolarDB安装与配置
730 0
|
存储 SQL 关系型数据库