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 @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的查询窗口里,右击窗口任意位置,选择“包含实际的执行计划”:
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中函数 replace 的参数1的数据类型ntext无效的解决方法
SQL中函数 replace 的参数 1 的数据类型 ntext 无效。找了半天找到了解决办法2010-06-06
windows无法停止SQLserver 服务的强制关闭进程方案(强制重启sqlserver Pol
今天在配置sqlserver需要重启的时候,提示其它服务也需要重启,但SQL Server PolyBase 数据移动 (MSSQLSERVER)无法重启了,这里就给出终极解决方法,强制关闭PolyBase 数据移动进程,再重启sqlserver就可以了2024-03-03
SQL Server数据表模糊查询(like用法)以及查询函数详解
使用SQL Server查询时经常会使用模糊查询,需要查询包含的指定字符串内容,这篇文章主要给大家介绍了关于SQL Server数据表模糊查询(like用法)以及查询函数的相关资料,需要的朋友可以参考下2024-05-05


最新评论