intersect 和 excepet的用法

        1.简介

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

  2.区别

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

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

  3.注意事项

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

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

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

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


例:有classInfo 和gradeInfo 两个表 的表结构一样

classInfo 的数据:

gradeInfo 的数据:


1.查询classInfo表和gradeInfo 表数据相同的记录:

select * from  gradeInfo
INTERSECT
select * from classInfo

结果:


2.查询classInfo 中排除表gradeInfo 数据的记录数(注意两个表的顺序别弄左了):

select * from   classInfo
except
select * from gradeInfo

结果:


end:其实两个运算符就是交集,补集的意思

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值