SQL 集合运算

SQL 中的集合运算用于对查询结果集进行操作,主要包括并集、交集和差集。常见的集合运算符有 UNIONINTERSECTEXCEPT(或 MINUS,具体取决于数据库系统)。

1. UNION

UNION 用于合并两个或多个查询结果集,并去除重复行。

sql 复制代码
SELECT column1, column2, ...
FROM table1
UNION
SELECT column1, column2, ...
FROM table2;
sql 复制代码
SELECT name FROM employees
UNION
SELECT name FROM contractors;

此查询返回 employeescontractors 表中所有不重复的 name


2. UNION ALL

UNION ALLUNION 类似,但保留重复行。

sql 复制代码
SELECT column1, column2, ...
FROM table1
UNION ALL
SELECT column1, column2, ...
FROM table2;
sql 复制代码
SELECT name FROM employees
UNION ALL
SELECT name FROM contractors;

此查询返回 employeescontractors 表中所有的 name 值,包括重复项


3. INTERSECT

INTERSECT 返回两个查询结果集的交集,即同时出现在两个结果集中的行。

sql 复制代码
SELECT column1, column2, ...
FROM table1
INTERSECT
SELECT column1, column2, ...
FROM table2;
sql 复制代码
SELECT name FROM employees
INTERSECT
SELECT name FROM contractors;

此查询返回同时存在于 employeescontractors 表中的 name


4. EXCEPT(或 MINUS)

EXCEPT 返回第一个查询结果集中存在但第二个结果集中不存在的行。

sql 复制代码
SELECT column1, column2, ...
FROM table1
EXCEPT
SELECT column1, column2, ...
FROM table2;
sql 复制代码
SELECT name FROM employees
EXCEPT
SELECT name FROM contractors;

此查询返回在 employees 表中但不在 contractors 表中的 name


注意事项

  • 参与集合运算的查询结果集必须具有相同的列数和数据类型。

  • UNIONINTERSECT 默认去除重复行,而 UNION ALL 保留重复行。

  • EXCEPT 在某些数据库系统中可能称为 MINUS


示例综合

假设有两个表 AB

表 A:

id name
1 Alice
2 Bob
3 Carol

表 B:

id name
2 Bob
3 Carol
4 Dave
sql 复制代码
SELECT name FROM A
UNION
SELECT name FROM B;

结果:

name
Alice
Bob
Carol
Dave
sql 复制代码
SELECT name FROM A
INTERSECT
SELECT name FROM B;

结果:

name
Bob
Carol
sql 复制代码
SELECT name FROM A
EXCEPT
SELECT name FROM B;

结果:

name
Alice

这些集合运算在数据分析和处理中非常有用,能够帮助我们从多个表中提取和比较数据

相关推荐
m0_6403093011 分钟前
如何用SQL统计每组的平均值同时显示原行_OVER子句
jvm·数据库·python
qq_3721542316 分钟前
Redis如何在应用启动时预热缓存数据
jvm·数据库·python
2601_9498153316 分钟前
Spring Boot中集成MyBatis操作数据库详细教程
数据库·spring boot·mybatis
解救女汉子21 分钟前
CSS如何利用CSS变量进行渐变色管理_提升渐变配置的灵活性
jvm·数据库·python
杨云龙UP28 分钟前
2000—CentOS Linux 7上部署Oracle 19c(19.3) RAC(RedHat/CentOS 7/8)
linux·运维·服务器·数据库·oracle·centos
m0_6784854535 分钟前
怎么导入只包含特定表的SQL文件_正则提取与分离导入
jvm·数据库·python
星晨雪海36 分钟前
若依框架原有页面功能进行了点位管理改造之列表查询(4)
数据库·sql·mybatis
历程里程碑38 分钟前
MySQL事务深度解析:ACID到MVCC实战+万字长文解析
开发语言·数据结构·数据库·c++·sql·mysql·排序算法
NineData41 分钟前
NineData 将亮相 2026 德国汉诺威工业博览会
数据库·人工智能·数据库管理工具·ninedata·数据库迁移工具·玖章算术
qq_432703661 小时前
MySQL中如何编写带有循环的函数_MySQL函数流程控制技巧
jvm·数据库·python