• sql 在not in 子查询有null值情况下经常出现的陷阱


    如果下:Table_A表和Table_B表,要求查询出在Table_A表中不在Table_B表中的记录。

    CREATE TABLE [dbo].[Table_A](
     [ID] [nchar](10) NULL,
     [Name] [nchar](10) NULL
    ) ON [PRIMARY]
    
    GO
    
    ID          Name
    001        张三        
    002        李四        
    003        王五              
    
     
    
    CREATE TABLE [dbo].[Table_B](
     [ID] [nchar](10) NULL,
     [Name] [nchar](10) NULL
    ) ON [PRIMARY]
    
    GO
    
    ID        Name
    NULL     张三        
    002       李四        
    NULL     王五 
    复制代码
    CREATE TABLE [dbo].[Table_A](
     [ID] [nchar](10) NULL,
     [Name] [nchar](10) NULL
    ) ON [PRIMARY]
    
    GO
    
    ID          Name
    001        张三        
    002        李四        
    003        王五              
    
     
    
    CREATE TABLE [dbo].[Table_B](
     [ID] [nchar](10) NULL,
     [Name] [nchar](10) NULL
    ) ON [PRIMARY]
    
    GO
    
    ID        Name
    NULL     张三        
    002       李四        
    NULL     王五 
    复制代码

    很容大家第一时间相当的写法是:

    SELECT  *
    FROM    dbo.Table_A AS a
    WHERE   a.ID NOT IN ( SELECT    b.ID
                          FROM      dbo.Table_B AS b)

    然而查询出来并没有达到预期的

    ID    Name
    001  张三        
    003  王五          

    原因很简单:由于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
    复制代码
    --正确写法                      
    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
    复制代码
  • 相关阅读:
    Sublime_text3怎么运行php代码
    (转)解决png图片在IE6下不透明的方法
    CSS+JS下拉菜单和纯CSS下拉菜单
    笔记本开了WIFI之后只能上QQ,上不了网页的解决方法
    常见的浏览器兼容问题
    学习正则表达式
    (转)各种排序比较 直观动画
    find job
    mongodb 索引,全文索引与唯一索引
    再谈闭包,几个例子分析
  • 原文地址:https://www.cnblogs.com/myhappylife/p/5520030.html
Copyright © 2020-2023  润新知