码迷,mamicode.com
首页 > 其他好文 > 详细

如何优雅的使用 参数 is null而不导致全表扫描(破坏索引)

时间:2019-04-08 17:25:18      阅读:569      评论:0      收藏:0      [点我收藏+]

标签:char   条件   temp   网上   冗余   values   位置   www   方案   

 

相信大家在很多实际业务中(特别是后台系统)会使用到各种筛选条件来筛选结果集

首先添加测试数据

CREATE TABLE TempList(Id int IDENTITY,Name VARCHAR(12),  Age INT)
go
CREATE INDEX idx_age ON TempList (Age)
GO


DECLARE @i INT;
SET @i=0;
WHILE @i<10000
BEGIN
  INSERT INTO TempList (Name, Age)VALUES(CAST(@i AS VARCHAR),@i)
  SET @i=@i+1;
END
GO

 

 

1.有使用EXEC来避免全表扫描

DECLARE @age INT=666;

DECLARE @sql NVARCHAR(MAX)
SET @sql = SELECT * FROM TempList

IF @age IS NOT NULL
    SET @sql = @sql +  WHERE Age = @age
    
EXEC sp_executesql @sql, N@age int, @age

或者条件少的情况下

DECLARE @age INT=666;

IF @age IS NOT NULL
    SELECT * FROM TempList WHERE Age = @age
ELSE 
    SELECT * FROM TempList

2.使用IS NULL来实现

DECLARE @age INT=666;

SELECT * FROM TempList WHERE (@age IS NULL OR Age = @age)

SELECT * FROM TempList WHERE (Age = @age OR @age IS NULL)

SELECT * FROM TempList WHERE Age=isnull(@age, Age) 

 

第一种方案,不会破坏索引,但冗余的代码看起来让人难受

技术图片

技术图片

第二种方案,会导致全表扫描(破坏索引)

技术图片

技术图片

 

以上是网上查阅的资料,方案二不符合SARG,问题在OR,如果我不使用OR,用AND呢

DECLARE @age INT=666;

SELECT * FROM TempList WHERE @age IS NOT NULL and Age = @age

技术图片

技术图片

 

 

版权声明:本文原创发表于 博客园,作者为 托大人 本文欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则视为侵权。

 

如何优雅的使用 参数 is null而不导致全表扫描(破坏索引)

标签:char   条件   temp   网上   冗余   values   位置   www   方案   

原文地址:https://www.cnblogs.com/robots/p/10671802.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!