• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    SQL中WHERE变量IS NULL条件导致全表扫描问题的解决方法

    复制代码 代码如下:

    SET @SQL = 'SELECT * FROM Comment with(nolock) WHERE 1=1
        And (@ProjectIds Is Null or ProjectId = @ProjectIds)
        And (@Scores is null or Score =@Scores)'


    印象中记得,以前在做Oracle开发时,这种写法是会导致全表扫描的,用不上索引,不知道Sql Server里是否也是一样呢,于是做一个简单的测试
    1、建立测试用的表结构和索引:
    复制代码 代码如下:

    CREATE TABLE aaa(id int IDENTITY, NAME VARCHAR(12), age INT)
    go
    CREATE INDEX idx_age ON aaa (age)
    GO

    2、插入1万条测试数据:

    复制代码 代码如下:

    DECLARE @i INT;
    SET @i=0;
    WHILE @i10000
    BEGIN
      INSERT INTO aaa (name, age)VALUES(CAST(@i AS VARCHAR), @i)
      SET @i=@i+1;
    END
    GO

    3、先开启执行计划显示:
    在SQL Server Management Studio的查询窗口里,右击窗口任意位置,选择“包含实际的执行计划”:

    4、开始测试,用下面的SQL进行测试:

    复制代码 代码如下:

    DECLARE @i INT;
    SET @i=100
    SELECT * FROM aaa WHERE (@i IS NULL OR age = @i)
    SELECT * FROM aaa WHERE (age = @i OR @i IS NULL)
    SELECT * FROM aaa WHERE age=isnull(@i, age)
    SELECT * FROM aaa WHERE age = @i

    测试结果如下:

    可以看到,即使@i有值,不管@i IS NULL是放在前面还是放在后面,都无法用到age的索引,另外age=ISNULL(@i,age)也用不上索引

    最终结论,SQL Server跟ORACLE一样,如果条件里加了 变量 IS NULL,都会导致全表扫描。

    建议SQL改成:

    复制代码 代码如下:

    DECLARE @i INT;
    SET @i=100

    DECLARE @sql NVARCHAR(MAX)
    SET @sql = 'SELECT * FROM aaa'
    IF @i IS NOT NULL
        SET @sql = @sql + ' WHERE age = @i'
    EXEC sp_executesql @sql, N'@i int', @i


    当然,如果只有一个条件,可以设计成2条SQL,比如:
    复制代码 代码如下:

    DECLARE @i INT;
    SET @i=100
    IF @i IS NOT NULL
        SELECT * FROM aaa WHERE age = @i
    ELSE
        SELECT * FROM aaa

    但是,如果条件多了,SQL数目也变得更多,所以建议用EXEC的方案

    您可能感兴趣的文章:
    • MySQL Where 条件语句介绍和运算符小结
    • MYSQL WHERE语句优化
    • MySQL 存储过程传参数实现where id in(1,2,3,...)示例
    • MySQL左联多表查询where条件写法示例
    • MySQL 联合索引与Where子句的优化 提高数据库运行效率
    • sql语句中where 1=1的作用
    • MySQL中union和join语句使用区别的辨析教程
    • SQL语句的并集UNION 交集JOIN(内连接,外连接)等介绍
    • 解析sql语句中left_join、inner_join中的on与where的区别
    • 解析mysql left( right ) join使用on与where筛选的差异
    • SQL中JOIN和UNION区别、用法及示例介绍
    • sql join on 用法
    • SQL where条件和jion on条件的详解及区别
    上一篇:SQL cursor用法实例
    下一篇:SQL多表连接查询实例分析(详细图文)
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    SQL中WHERE变量IS NULL条件导致全表扫描问题的解决方法 SQL,中,WHERE,变量,NULL,条件,