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)的主要内容,如果未能解决你的问题,请参考以下文章