加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

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

发布时间:2020-12-12 13:52:23 所属栏目:MsSql教程 来源:网络整理
导读:SQLServer中通过intersect,union,except和三个关键字对应交、并、差三种集合运算。 他们的对应关系可以参考下面图示 测试示例: 构造A,B两个数据集 A: 1 , 2 , 3 , 4 B: 1 , 5 WITH A AS ( SELECT ‘ 1 ‘ tno UNION ALL SELECT ‘ 2 ‘ UNION ALL SELECT ‘

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

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

测试示例:

构造A,B两个数据集

A:1,2,3,4  
B:1,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,1,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;  

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读