SQL SERVER中EXCEPT/INTERSECT,CASE/ISNULL/COALESCE

SQL SERVER中EXCEPT/INTERSECT,CASE/ISNULL/COALESCE


EXCEPT 和 INTERSECT


一般解释:比较两个查询的结果,返回非重复值。

EXCEPT 从左查询中返回右查询没有找到的所有非重复值。

INTERSECT 返回 左右两边的两个查询都包含的所有非重复值。

以下是将使用 EXCEPT 或 INTERSECT 的两个查询的结果集组合起来的基本规则:

  • 所有查询中的列数和列的顺序必须相同。

  • 数据类型必须兼容。

假设test表中testid包含1,1,2,3,4,4;test2表中id包含1,2,3,4,5,6

select testid from test
intersect
select id from test2

结果只有1,2,3,4。

select id from test2
except
select testid from test


结果只有5,6.


对比CASE, ISNULL, COALESCE


ISNULL和COALESCE大体上相同,相当于CASE 语句:

CASE

   WHEN (expression1 IS NOT NULL) THEN expression1

   WHEN (expression2 IS NOT NULL) THEN expression2

   ...

   ELSE expressionN

END

ISNULLCOALESCE还是不同的。

SELECT ISNULL(NULL,NULL)返回NULL。

SELECT COALESCE(NULL,NULL)则报错:至少有一个参数不能为空。

ISNULL只能有两个参数,如ISNULL(1,NULL),而COALESCE则可以有多个参数,如COALESCE(NULL,3,NULL,1)。

ISNULL最终返回值类型跟第一个参数类型相同。如果两个参数的类型不同并最终返回值等于第二个参数,则会把第二个参数进行隐式转换为第一个参数的类型再返回。

如,

DECLARE @Field1 char(4), @Field2 char(50)
SET @Field2 = ‘LeeWhoee University‘
SELECT ISNULL(@Field1, @Field2)
--返回 ‘LeeW‘
SELECT COALESCE(@Field1, @Field2)
--返回 ‘LeeWhoee University‘



SQL SERVER中EXCEPT/INTERSECT,CASE/ISNULL/COALESCE,布布扣,bubuko.com

SQL SERVER中EXCEPT/INTERSECT,CASE/ISNULL/COALESCE

上一篇:浅谈mysql的两阶段提交协议


下一篇:MSSQL数据库中Text类型字段在PHP中被截断之解 (转)