SQL Server 2005 EXCEPT与INTERSECT的区别

数据库 SQL Server
我们今天主要向大家描述的是SQL Server 2005 EXCEPT与INTERSECT运算符的正确使用以及对其实际操作的不同之处的讲述。

此文章主要向大家描述的是SQL Server 2005 EXCEPT与INTERSECT运算符的正确使用,同时本文也有对EXCEPT与INTERSECT运算符的实际应用的比较,以及对其在实际操作中值得我们大家注意的相关事项的描述。

1.简介

 

SQL Server 2005 EXCEPT和INTERSECT运算符使您可以比较两个或多个SELECT语句的结果并返回非重复值。

2.区别

EXCEPT运算符返回由EXCEPT运算符左侧的查询返回、而又不包含在右侧查询所返回的值中的所有非重复值。

INTERSECT返回由INTERSECT运算符左侧和右侧的查询都返回的所有非重复值。

3.注意事项

(1).使用SQL Server 2005 EXCEPT或INTERSECT比较的结果集必须具有相同的结构。它们的列数必须相同,并且相应的结果集列的数据类型必须兼容

(2).INTERSECT运算符优先于EXCEPT

(3).SELECT INTO必须是包含INTERSECT或EXCEPT运算符的语句中的***个查询,用来创建容纳最终结果集的表

(4).ORDER BY子句中的列名或别名必须引用左侧查询返回的列名

4.例题:

建立3个表,分别插入数据

  1. create table TableA(col1 int)   
  2. insert into TableA select 1   
  3. insert into TableA select 1   
  4. insert into TableA select 2   
  5. insert into TableA select 3   
  6. insert into TableA select 4   
  7. insert into TableA select 4   
  8. insert into TableA select 5   
  9. insert into TableA select null   
  10. insert into TableA select null   
  11. create table TableB(col2 int)   
  12. insert into TableB select null   
  13. insert into TableB select 1   
  14. insert into TableB select 2   
  15. insert into TableB select 3   
  16. create table TableC(col3 int)   
  17. insert into TableC select 1   
  18. insert into TableC select 5   
  19. insert into TableC select 6  

利用SQL Server 2005 EXCEPT

找出TableA表的col1列不存在Tablec表col1列的所有非重复值

  1. SELECT col1 FROM TableA   
  2. EXCEPT   
  3. SELECT col3 FROM Tablec  

结果如下:

  1. col1   
  2. -   
  3. NULL   
  4. 2   
  5. 3   
  6. 4   

sql 2000的版本,用not exists实现SQL Server 2005 EXCEPT的功能

  1. SELECT col1   
  2. FROM TableA as a   
  3. where not exists(SELECT col3 FROM Tablec where a.col1=col3)   
  4. group by col1  

sql 2000,not in是得不到上述结果的

空值表示值未知。空值不同于空白或零值。没有两个相等的空值。

比较两个空值或将空值与任何其他值相比均返回未知,这是因为每个空值均为未知。

使用IN或NOT IN比较后返回的所有空值都将返回UNKNOWN。

将空值与IN或NOT IN一起使用会产生意外结果。

  1. SELECT col1   
  2. FROM TableA   
  3. where col1 not in(SELECT col3 FROM Tablec)   
  4. group by col1  

结果如下:

  1. col1   
  2. -   
  3. 2   
  4. 3   
  5. 4   

INTERSECT运算符优先于EXCEPT

运算步骤是:先运算TableB和TableC的INTERSECT,再和TableA运算SQL Server 2005 EXCEPT

  1. SELECT col1 FROM TableA   
  2. EXCEPT   
  3. SELECT col2 FROM TableB   
  4. INTERSECT   
  5. SELECT col3 FROM TableC  

结果如下:

  1. col1   
  2. -   
  3. NULL   
  4. 2   
  5. 3   
  6. 4   
  7. 5   

SELECT INTO的应用

SELECT INTO必须是语句中的***个查询

我记得SELECT INTO与UNION运算符的使用也是这样的规则

  1. SELECT col1   
  2. into #tem   
  3. FROM TableA   
  4. EXCEPT   
  5. SELECT col3   
  6. FROM Tablec   
  7. select * from #tem   
  8. drop table #tem 

结果如下:

  1. col1   
  2. -   
  3. NULL   
  4. 2   
  5. 3   
  6. 4   

ORDER BY子句

ORDER BY子句中的列名或别名必须引用左侧查询返回的列名

  1. SELECT col1 FROM TableA   
  2. INTERSECT   
  3. SELECT col3 FROM TableC   
  4. order by col1  

结果如下:

  1. col1   
  2. -   
  3. 1   
  4. 5   

 

上述的相关内容就是对SQL Server 2005中EXCEPT和INTERSECT运算符的使用的描述,希望会给你带来一些帮助在此方面。

【编辑推荐】

  1. SQL Server identity列,美中不足之处
  2. SQL Server DateTime数据类型的另类解读
  3. SQL Server 2000的安全策略的正确打造
  4. SQL Server 数据导入的实际行为规范描述
  5. MS SQL Server问题与其正确解答方案

 

责任编辑:佚名 来源: CNW
相关推荐

2011-04-18 13:02:08

SQL Server SQL Server

2010-07-06 10:36:35

SQL Server

2011-07-06 13:09:11

SQL Server

2010-07-26 17:43:34

SQL Server

2010-06-17 15:09:49

SQL Server

2010-07-23 12:55:29

SQL Server

2011-02-28 17:41:20

SQL Server

2010-07-14 17:32:53

SQL Server

2011-09-07 15:11:31

SQL Server同步

2010-07-09 11:06:13

SQL Server

2010-06-28 13:51:18

SQL Server

2010-10-21 15:13:20

SQL Server系

2010-06-28 14:49:51

SQL Server

2011-03-29 15:27:26

SQL Server 动态管理

2010-06-30 08:34:27

SQL Server

2010-07-16 11:30:06

SQL Server

2010-07-16 10:35:19

SQL Server

2011-03-25 10:04:51

2011-09-01 16:13:37

Visual StudSQL Server 存储过程

2010-09-03 10:40:30

SQL删除
点赞
收藏

51CTO技术栈公众号