PostgreSQL-06-入门篇-集合运算

embedded/2025/2/4 18:08:04/

文章目录

    • 1. UNION 组合多个查询的结果集
      • 简介
      • 带有 ORDER BY 子句的 UNION
      • 设置样例表
      • PostgreSQL UNION 示例
        • 1) 简单的 PostgreSQL UNION 示例
        • 2) PostgreSQL UNION ALL 示例
        • 3) 带 ORDER BY 子句 UNION ALL 示例
    • 2. INTERSECT 取交集
      • 简介
      • 带 ORDER BY 子句的 INTERSECT 操作
      • PostgreSQL INTERSECT 运算符示例
    • 3. EXCEPT 取差集
      • 简介
      • PostgreSQL EXCEPT 运算符示例
      • 概括

1. UNION 组合多个查询的结果集

简介

UNION运算符将两个或多个SELECT语句的结果集组合成一个结果集。

下面说明了组合两个查询的结果集的UNION运算符的语法:

SELECT select_list_1
FROM table_expresssion_1
UNION
SELECT select_list_2
FROM table_expression_2

要使用UNION运算符组合两个查询的结果集,查询必须符合以下规则:

  • 两个查询的选择列表中列的数量和顺序必须相同。
  • 数据类型必须兼容。

UNION运算符从组合数据集中删除所有重复行。要保留重复的行,请改用UNION ALL

下面的维恩图说明了UNION工作原理:

在这里插入图片描述

带有 ORDER BY 子句的 UNION

UNION运算符可以将第一个查询的结果集中的行放置在第二个查询的结果集中的行之前、之后或之间。

要对最终结果集中的行进行排序,请在第二个查询中使用ORDER BY子句。

在实践中,您可能会使用UNION运算符来组合来自数据仓库或商业智能系统中未完全规范化的相似表的数据。

设置样例表

以下语句创建两个表:top_rated_filmsmost_popular_films,并向这些表中插入数据:

DROP TABLE IF EXISTS top_rated_films;
CREATE TABLE top_rated_films(
title VARCHAR NOT NULL,
release_year SMALLINT
);DROP TABLE IF EXISTS most_popular_films;
CREATE TABLE most_popular_films(
title VARCHAR NOT NULL,
release_year SMALLINT
);INSERT INTO top_rated_films(title,release_year)
VALUES('The Shawshank Redemption',1994),('The Godfather',1972),('12 Angry Men',1957);INSERT INTO most_popular_films(title,release_year)
VALUES('An American Pickle',2020),('The Godfather',1972),('Greyhound',2020);

top_rated_films表中数据如下所示:

SELECT * FROM top_rated_films;

在这里插入图片描述

以下语句返回most_popular_films表中的数据:

SELECT * FROM most_popular_films;

在这里插入图片描述

PostgreSQL UNION 示例

让我们看一些使用 PostgreSQL 的UNION运算符的示例。

1) 简单的 PostgreSQL UNION 示例

以下语句使用UNION运算符组合两个表中的数据:


SELECT * FROM top_rated_films
UNION
SELECT * FROM most_popular_films;

查询返回以下结果:

在这里插入图片描述

由于UNION运算符删除了 1 个重复行,因此结果集中包含 5 行。

2) PostgreSQL UNION ALL 示例

以下语句使用UNION ALL运算符组合top_rated_filmsmost_popular_films表中的结果集:

SELECT * FROM top_rated_films
UNION ALL
SELECT * FROM most_popular_films;

在这里插入图片描述

在此示例中,重复行保留在结果集中。

3) 带 ORDER BY 子句 UNION ALL 示例

要对UNION运算符返回的结果进行排序,请将ORDER BY子句放在最后一个查询的末尾,如下所示:

SELECT * FROM top_rated_films
UNION ALL
SELECT * FROM most_popular_films
ORDER BY title;

在这里插入图片描述

如果将ORDER BY子句放置在每个查询的末尾,则组合结果集将不会按您预期的方式排序。

因为当UNION运算符合并每个查询的排序结果集时,它不能保证最终结果集中行的顺序。

2. INTERSECT 取交集

简介

UNIONEXCEPT运算符类似,PostgreSQL 的INTERSECT运算符将两个或多个SELECT语句的结果集组合成一个结果集。

INTERSECT运算符返回两个结果集中可用的任何行。

下图显示了INTERSECT运算符产生的最终结果集。

在这里插入图片描述

最终结果集由圆 A 与圆 B 相交的黄色区域表示。

下面说明了INTERSECT运算符的语法:

SELECT select_list
FROM A
INTERSECT
SELECT select_list
FROM B;

要使用INTERSECT运算符,SELECT语句中出现的列必须遵循以下规则:

  1. SELECT列表中的列数及其顺序必须相同。
  2. 列的数据类型必须兼容。

带 ORDER BY 子句的 INTERSECT 操作

如果要对INTERSECT运算符返回的结果集进行排序,请将ORDER BY放在查询列表中的最终查询处,如下所示:

SELECT select_list
FROM A
INTERSECT
SELECT select_list
FROM B
ORDER BY sort_expression;

PostgreSQL INTERSECT 运算符示例

我们将使用第一章 UNION 组合多个查询的结果集 中创建的top_rated_filmsmost_popular_films

要获取热门的同时也是评分最高的电影,您可以使用INTERSECT运算符,如下:

SELECT *
FROM most_popular_films 
INTERSECT
SELECT *
FROM top_rated_films;

在这里插入图片描述

结果集返回了同时出现在两个表中的一部影片。

3. EXCEPT 取差集

简介

UNIONINTERSECT运算符类似,EXCEPT运算符通过比较两个或多个查询的结果集来返回行。

EXCEPT运算符返回第一个(左)查询中不在第二个(右)查询的输出中的不同行。

下面说明了EXCEPT运算符的语法。

SELECT select_list
FROM A
EXCEPT
SELECT select_list
FROM B;

EXCEPT涉及到的查询需要遵循以下规则:

  • 两个查询中的列数及其顺序必须相同。
  • 各列的数据类型必须兼容。

下面的维恩图说明了EXCEPT运算符:

在这里插入图片描述

PostgreSQL EXCEPT 运算符示例

我们将使用第一章 UNION 组合多个查询的结果集 中创建的top_rated_filmsmost_popular_films

以下语句使用EXCEPT运算符查找评分最高但不受欢迎的电影:

SELECT * FROM top_rated_films
EXCEPT 
SELECT * FROM most_popular_films;

在这里插入图片描述

以下语句使用查询中的ORDER BY子句对EXCEPT运算符返回的结果集进行排序:

SELECT * FROM top_rated_films
EXCEPT
SELECT * FROM most_popular_films
ORDER BY title;

请注意,我们将 ORDER BY 子句放在语句末尾,以按标题对电影进行排序。

概括

  • 使用 PostgreSQL 的EXCEPT运算符获取第一个查询中未出现在第二个查询的结果集中的行。

http://www.ppmy.cn/embedded/134284.html

相关文章

《Python游戏编程入门》注-第4章6

《Python游戏编程入门》的“轮询鼠标”内容介绍了通过轮询鼠标实现实时显示鼠标位置和按键状态的游戏。 1 游戏介绍 实时显示鼠标位置和按键状态的游戏如图1所示。 图1 实时显示鼠标位置和按键状态 从图1中可以看到,游戏界面主要分为上下两部分。其中&#xff0c…

前端自学资料(笔记八股)分享—CSS(4)

更多详情:爱米的前端小笔记(csdn~xitujuejin~zhiHu~Baidu~小红shu)同步更新,等你来看!都是利用下班时间整理的,整理不易,大家多多👍💛➕🤔哦!你们…

Redis在计数器和人员记录的事务操作应用

文章目录 解决计数器和人员记录的事务操作计数器操作人员记录的事务操作事务(Transaction)示例:使用事务添加或更新人员记录多路复用(Pipeline)示例:使用 Pipeline 添加或更新人员记录 注意事项 解决计数器…

基于springboot的旅游出行指南

文章目录 项目介绍主要功能截图:部分代码展示设计总结项目获取方式🍅 作者主页:超级无敌暴龙战士塔塔开 🍅 简介:Java领域优质创作者🏆、 简历模板、学习资料、面试题库【关注我,都给你】 🍅文末获取源码联系🍅 项目介绍 基于springboot的旅游出行指南,java项目…

泰国电商市场现状,消费者喜欢的电商平台有哪些?

据外媒报道,泰国电商市场预计到2024年底,收入将达到1.1万亿泰铢,同比增长 14%,相较于2023年的9800亿泰铢有显著增长。 预计泰国电商市场将持续扩大,到2027年可能达到1.6万亿泰铢。同时,到2025年&#xff0c…

吞吐量最高飙升20倍!破解强化学习训练部署难题

**强化学习(RL)对大模型复杂推理能力提升有关键作用,然而,RL 复杂的计算流程以及现有系统局限性,也给训练和部署带来了挑战。近日,字节跳动豆包大模型团队与香港大学联合提出 HybridFlow(开源项…

在 Android 设备上部署一个 LLM(大语言模型)并通过 Binder 通信提供服务

在 Android 设备上部署一个 LLM(大语言模型)并通过 Binder 通信提供服务,需要以下几个步骤。具体实现是通过定义一个 Android HAL 服务,并且在 init.rc 文件中启动该服务。我们将一步一步解释如何实现一个可通过 Binder 通信的服务(如 vendor.te.aimodel-service)。 一 …

Linux---硬盘管理

文章目录 前言一、pandas是什么?二、使用步骤 1.引入库2.读入数据总结 一.硬盘概述 物理结构 硬盘一般由多个盘片组成,每个盘片有正两面,每个盘片都对应一个读写磁头。 下图显示的是一个磁盘盘面,盘面中一个个灰色的圆圈就是一条…