【PostgreSQL】数据查询-组合查询(UNION,INTERSECT,EXCEPT)

可以使用集合运算并集、交集和差值来组合两个查询的结果。语法是

sql 复制代码
query1 UNION [ALL] query2
query1 INTERSECT [ALL] query2
query1 EXCEPT [ALL] query2

其中 query1 和 query2 是可以使用到目前为止讨论的任何功能的查询。

UNION有效地将 query2 的结果追加到 query1 的结果(尽管不能保证这是实际返回行的顺序)。此外,它从其结果中消除重复的行,其方式与DISTINCT 相同,除非使用UNION ALL。

INTERSECT返回 Query1 的结果和 Query2 的结果中的所有行。除非使用重复行,否则将消除重复行。

EXCEPT返回 Query1 结果中但不在 Query2 结果中的所有行。(这有时称为两个查询之间的差异。同样,除非使用,否则将消除重复项。

为了计算两个查询的并集、交集或差值,这两个查询必须"并集兼容",这意味着它们返回相同数量的列,并且相应的列具有兼容的数据类型。

集合操作可以组合,例如

sql 复制代码
query1 UNION query2 EXCEPT query3

这相当于

sql 复制代码
(query1 UNION query2) EXCEPT query3

如此处所示,您可以使用括号来控制计算顺序。不带括号,从左到右关联,但比这两个运算符绑定得更紧密。因此

sql 复制代码
query1 UNION query2 INTERSECT query3

方法

sql 复制代码
query1 UNION (query2 INTERSECT query3)

还可以用括号将单个查询括起来。如果查询需要使用以下各节中讨论的任何子句,例如 .如果没有括号,您将收到语法错误,否则该子句将被理解为应用于集合操作的输出,而不是其输入之一。例如LIMIT

sql 复制代码
SELECT a FROM b UNION SELECT x FROM y LIMIT 10

被接受,但这意味着

sql 复制代码
(SELECT a FROM b UNION SELECT x FROM y) LIMIT 10

而不能接受

sql 复制代码
SELECT a FROM b UNION (SELECT x FROM y LIMIT 10)
相关推荐
YashanDB1 小时前
【YashanDB知识库】XMLAGG方法的兼容
数据库·yashandb·崖山数据库
独行soc2 小时前
#渗透测试#漏洞挖掘#红蓝攻防#护网#sql注入介绍11基于XML的SQL注入(XML-Based SQL Injection)
数据库·安全·web安全·漏洞挖掘·sql注入·hw·xml注入
小林coding2 小时前
阿里云 Java 后端一面,什么难度?
java·后端·mysql·spring·阿里云
风间琉璃""3 小时前
bugkctf 渗透测试1超详细版
数据库·web安全·网络安全·渗透测试·内网·安全工具
drebander3 小时前
SQL 实战-巧用 CASE WHEN 实现条件分组与统计
大数据·数据库·sql
IvorySQL3 小时前
IvorySQL 4.0 发布:全面支持 PostgreSQL 17
数据库·postgresql·开源数据库·国产数据库·ivorysql
18号房客3 小时前
高级sql技巧进阶教程
大数据·数据库·数据仓库·sql·mysql·时序数据库·数据库架构
Dawnㅤ3 小时前
使用sql实现将一张表的某些字段数据存到另一种表里
数据库·sql
张声录13 小时前
【ETCD】【实操篇(十二)】分布式系统中的“王者之争”:基于ETCD的Leader选举实战
数据库·etcd
运维&陈同学3 小时前
【模块一】kubernetes容器编排进阶实战之基于velero及minio实现etcd数据备份与恢复
数据库·后端·云原生·容器·kubernetes·etcd·minio·velero