ps122

导航

 
由于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

  

 


posted on 2017-07-31 10:10  ps122  阅读(208)  评论(0编辑  收藏  举报