SQLServer中通过intersect,union,except和三个关键字对应交、并、差三种集合运算。
他们的对应关系可以参考下面图示
测试示例:
构造A,B两个数据集
A:1,2,3,4
B:1,2,5
WITH A AS
(SELECT '' tno
UNION ALL SELECT '' UNION ALL SELECT '' UNION ALL SELECT ''
),
B AS(SELECT '' tno
UNION ALL SELECT '' UNION ALL SELECT '')
查询示例:
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;