主页 > 知识库 > SQL中WHERE变量IS NULL条件导致全表扫描问题的解决方法

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

热门标签:阳光创信ai外呼获客系统助力 云南全自动外呼系统公司 竞圣地图标注服务 安阳天音防封电销卡 外呼系统的话术 智能外呼系统需要多少钱 智能语音车载电话机器人 卫星地图标注距离 贵州外呼回拨系统是什么

复制代码 代码如下:

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中WHERE变量IS NULL条件导致全表扫描问题的解决方法》,本文关键词  SQL,中,WHERE,变量,NULL,条件,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《SQL中WHERE变量IS NULL条件导致全表扫描问题的解决方法》相关的同类信息!
  • 本页收集关于SQL中WHERE变量IS NULL条件导致全表扫描问题的解决方法的相关信息资讯供网民参考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推荐文章