相信大家在很多实际业务中(特别是后台系统)会使用到各种筛选条件来筛选结果集
首先添加测试数据
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
版权声明:本文原创发表于 博客园,作者为 托大人 本文欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则视为侵权。
原文地址:https://www.cnblogs.com/robots/p/10671802.html
时间: 2024-10-20 14:23:43