码迷,mamicode.com
首页 > 数据库 > 详细

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

时间:2018-05-29 01:44:51      阅读:195      评论:0      收藏:0      [点我收藏+]

标签:重复数   差集   com   bsp   重复   int   exce   集合运算   nbsp   

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)

标签:重复数   差集   com   bsp   重复   int   exce   集合运算   nbsp   

原文地址:https://www.cnblogs.com/jijm123/p/9103013.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!