【发布时间】:2010-02-04 20:03:37
【问题描述】:
我有一个名为 NUMS 的表,其中只有一列 n。
我在其中填充值 1,2,3,4,5,null 。
现在是一个查询
SELECT n FROM Nums
WHERE n IN (1, 2, null)
在这种情况下,我猜它已转换为
SELECT n FROM Nums
Where n = 1 OR n = 2 OR n = null
我还将 n 与一个 null 值进行比较,它应该产生未知并且它应该返回一个空集。但是它返回 1,2(null 不返回,尽管包含在 IN 运算符中)
现在是一个查询
SELECT n FROM Nums WHERE n NOT IN(1, 2, null)
...转换为:
SELECT n FROM Nums
Where n!=1 AND n!=2 AND n!=null
我上面所说的在这里有效,它没有返回任何东西。
谁能详细解释发生了什么。
【问题讨论】:
标签: sql sql-server