sql – NULL值被排除.为什么?
发布时间:2020-12-12 16:20:49 所属栏目:MsSql教程 来源:网络整理
导读:这是我在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','Renegotiat
这是我在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的一部分. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |