由于NULL不能进行如何的“操作”
–如果null参与算术运算,则该算术表达式的值为null。(例如:+,-,*,/ 加减乘除)
–如果null参与比较运算,则结果可视为false。(例如:>=,<=,<> 大于,小于,不等于)
–如果null参与聚集运算,则聚集函数都置为null。除count(*)之外。
--如果在not in子查询中有null值的时候,则不会返回数据。
--正确写法
SELECT *FROM dbo.Table_A AS a
WHERE a.ID NOT IN ( SELECT b.ID
FROM dbo.Table_B AS b
WHERE b.ID IS NOT NULL ) --排除NULL值参与运算符比较
--建议修改为关联查询方法
--正确写法1
SELECT *FROM dbo.Table_A AS a
WHERE NOT EXISTS ( SELECT * FROM dbo.Table_B AS b
WHERE a.ID = b.ID )
--正确写法2
SELECT *FROM dbo.Table_A AS a
LEFT OUTER JOIN dbo.Table_B AS b ON a.ID = b.ID
WHERE b.ID IS NULL
浙公网安备 33010602011771号