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

来源:互联网 发布:网络遭遇撞库攻击 编辑:程序博客网 时间:2024/05/10 19:32

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

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

测试示例:

构造A,B两个数据集

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

查询示例:

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

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

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

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

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

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

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

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


0 0
原创粉丝点击