SQL Server SQL中WHERE变量IS NULL条件导致全表扫描问题的解决方法
2022-11-12 09:44:45
内容摘要
这篇文章主要为大家详细介绍了SQL Server SQL中WHERE变量IS NULL条件导致全表扫描问题的解决方法,具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的
文章正文
这篇文章主要为大家详细介绍了SQL Server SQL中WHERE变量IS NULL条件导致全表扫描问题的解决方法,具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术笔记!
代码如下:
1 2 3 | <code>SET @SQL = 'SELECT * FROM Comment with(nolock) WHERE 1=1 And (@ProjectIds Is Null or ProjectId = @ProjectIds) And (@Scores is null or Score =@Scores)'</code> |
代码如下:
1 2 3 4 | <code>CREATE TABLE aaa(id int IDENTITY, NAME VARCHAR(12), age INT) go CREATE INDEX idx_age ON aaa (age) GO</code> |
2、插入1万条测试数据:
代码如下:
1 2 3 4 5 6 7 8 9 | <code>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 </code> |
4、开始测试,用下面的SQL进行测试:
代码如下:
1 2 3 4 5 6 7 | <code>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 </code> |
可以看到,即使@i有值,不管@i IS NULL是放在前面还是放在后面,都无法用到age的索引,另外age=ISNULL(@i,age)也用不上索引
最终结论,SQL Server跟ORACLE一样,如果条件里加了 变量 IS NULL,都会导致全表扫描。
建议SQL改成:
代码如下:
1 2 | <code>DECLARE @i INT; SET @i=100</code> |
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
代码如下:
1 2 3 4 5 6 7 | <code>DECLARE @i INT; SET @i=100 IF @i IS NOT NULL SELECT * FROM aaa WHERE age = @i ELSE SELECT * FROM aaa </code> |
但是,如果条件多了,SQL数目也变得更多,所以建议用EXEC的方案
注:关于SQL Server SQL中WHERE变量IS NULL条件导致全表扫描问题的解决方法的内容就先介绍到这里,更多相关文章的可以留意
代码注释