SQLSERVER数据集合的交并差集运算(intersect,union,except)

Posted 癫狂编程

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQLSERVER数据集合的交并差集运算(intersect,union,except)相关的知识,希望对你有一定的参考价值。

SQLServer中通过intersect,union,except和三个关键字对应交、并、差三种集合运算。

他们的对应关系可以参考下面图示

测试示例:

构造A,B两个数据集

A:1,2,3,4  
B:1,2,5  
WITH A AS  
(SELECT \'1\' tno  
UNION ALL SELECT  \'2\' UNION ALL SELECT  \'3\' UNION ALL SELECT  \'4\'   
),  
B AS(SELECT \'1\' tno  
UNION ALL SELECT  \'2\' UNION ALL SELECT  \'5\')  

查询示例:

1 Union 取合集并过滤重复数据

--1 Union 取合集并过滤重复数据  
--结果显示: 1,2,3,4,5  
SELECT * FROM A  
UNION     
SELECT * FROM B;  

2 Union all 取合集不过滤重复数据

--2 Union all 取合集不过滤重复数据  
--结果显示:1,2,3,4,1,2,5  
SELECT * FROM A  
UNION  all  
SELECT * FROM B;  

3 Intersect 取交集(两个表中都有数据)

--3 Intersect 取交集  
--结果显示:1,2  
SELECT * FROM A  
Intersect    
SELECT * FROM B;  

4 except 取差集(取A-B的记录)

--4 except 取差集  
--结果显示:3,4  
SELECT * FROM A  
except    
SELECT * FROM B;  

 

以上是关于SQLSERVER数据集合的交并差集运算(intersect,union,except)的主要内容,如果未能解决你的问题,请参考以下文章

c_cpp 集合的交并差运算

Oracle入门第六天(中)——SET运算符(交并差集)

使用高级程序设计语言实现集合的交并差运算

MySQL中的交并差

TOJ 1743集合运算(set集合并交差的运用)

数据库中的集合运算