SQL中WHERE变量IS NULL条件导致全表扫描问题的解决
网络编程 2021-07-05 13:42www.168986.cn编程入门
今天在评审接手的项目中的存储过程时,发现存在大量的在条件里判断变量是否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、开始测试,用狼蚁网站SEO优化的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的方案
上一篇:SQL多表连接查询实例分析(详细图文)
下一篇:SQL cursor用法实例
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程