手机
当前位置:查字典教程网 >编程开发 >mssql数据库 >SQL中WHERE变量IS NULL条件导致全表扫描问题的解决方法
SQL中WHERE变量IS NULL条件导致全表扫描问题的解决方法
摘要:复制代码代码如下:SET@SQL='SELECT*FROMCommentwith(nolock)WHERE1=1And(@ProjectId...

复制代码 代码如下:

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 @i<10000

BEGIN

INSERT INTO aaa (name, age)VALUES(CAST(@i AS VARCHAR), @i)

SET @i=@i+1;

END

GO

3、先开启执行计划显示:

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

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

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

测试结果如下:

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

可以看到,即使@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的方案

【SQL中WHERE变量IS NULL条件导致全表扫描问题的解决方法】相关文章:

SQLServer2005 没有服务器名称的两种解决方法

sql2005 批量更新问题的解决方法

SQL 合并多行记录的方法总汇

安装SQL2005时出现的版本变更检查SKUUPGRADE=1问题的解决方法

SQL Server 2008 阻止保存要求重新创建表的更改问题的设置方法

MSSQL 大量数据时,建立索引或添加字段后保存更改提示超时的解决方法

LINQ to SQL:处理char(1)字段的方式会引起全表扫描问题

安装SQL2005提示 找不到任何SQL2005组件的问题解决方案

Win7 安装软件时无法连接sql server解决方法

SQL SERVER清除日志的方法

精品推荐
分类导航