sql – NULL值被排除.为什么?

前端之家收集整理的这篇文章主要介绍了sql – NULL值被排除.为什么?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
这是我在Microsoft sql Server中发现的一个奇怪的行为.如果我错了请纠正我
SELECT COUNT(*) FROM TABLEA 
WHERE [Column1] IS NULL;

这返回30018行.

CREATE VIEW VIEWB AS 
SELECT * FROM TABLEA AS t1 
WHERE t1.[Column1] NOT IN ('Cross/Up sell','Renegotiation','Renewal')

如果我查看VIEWB,我在Column1中找不到NULL:

SELECT COUNT(*) FROM VIEWB 
WHERE [Column1] IS NULL;

这返回0行.

为什么?上面的查询排除了3个值,但不应该排除NULL.为什么Ms sql Server的行为是这样的?我应该预期吗
我该怎么解决

解决方法

这实际上是sql Server在将NULL视为值时发生的常见错误.默认情况下,它被视为UNKNOWN,如文档 here.因此,在您看来,还需要包含一个OR t1.[Column1] IS NULL.

您可以通过调用SET ANSI_NULLS OFF来更改此行为.不建议使用这一点,但是,由于@Martin Smith所指出的功能已被弃用.

但是,这不是sql Server的具体问题.它是ANSI SQL standard的一部分.

猜你在找的MsSQL相关文章