SQL Server EXCEPT

EXCEPT(差集)集合运算, 对两个输入查询的结果集合进行操作,返回出现第一个结果集中,但不出现在第二个结果集中的所有行。

为了演示,首选创建两个变量表,并插入数据:

 第一个表:

代码
DECLARE @T1 AS TABLE(ColName1 NVARCHAR(50),ColName2 NVARCHAR(50))
INSERT INTO @T1 VALUES ('tc1','tc2');
INSERT INTO @T1 VALUES ('tc3','tc4');
INSERT INTO @T1 VALUES ('tc5','tc6');
INSERT INTO @T1 VALUES ('tc13','tc14');

 
第二个表:

代码
DECLARE @T2 AS TABLE(ColName1 NVARCHAR(50),ColName2 NVARCHAR(50))
INSERT INTO @T2 VALUES ('tc1','tc2');
INSERT INTO @T2 VALUES ('tc3','tc4');
INSERT INTO @T2 VALUES ('tc9','tc10');
INSERT INTO @T2 VALUES ('tc7','tc8');

 
EXCEPT差集运算:

SELECT * FROM @T1 
EXCEPT
SELECT * FROM @T2 

 

结果:

 

为了更清楚,现把EXCEPT差集运算的两个表对调一下,

SELECT * FROM @T2 
EXCEPT
SELECT * FROM @T1 

 

结果:

posted @ 2011-01-04 19:06  Insus.NET  阅读(1013)  评论(0编辑  收藏  举报