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

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

首先添加测试数据

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

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

Preconditions优雅的检验参数

Preconditions优雅的检验参数 在日常开发中,我们经常会对方法的输入参数做一些数据格式上的验证,以便保证方法能够按照正常流程执行下去.对于可预知的一些数据上的错误,我们一定要做事前检测和判断,来避免程序流程出错,而不是完全通过错误处理来保证流程正确执行,毕竟错误处理是比较消耗资源的方式.在平常情况下我们对参数的判断都需要自己来逐个写方法判断,代码量不少并且复用性不高,如下所示: import org.junit.Test; public class PreconditionsTest

XFile客户端调用JDK1.6+的webserivce时参数为null

Webservice的服务端用JDK1.6+自带的Webservice做的,客户端用的是XFile的webservice调用的,但是传过来的参数为NULL. XFile的调用方式是: String wsdl = "http://192.168.1.112:8088/testService?wsdl"; try { Client client = new Client(new URL(wsdl)); String result = client.invoke("test&quo

(转)Delphi 调用C#编写的WebService 参数为Null解决方法 附中文乱码问题

(转)Delphi 调用C#编写的WebService 参数为Null解决方法 附中文乱码问题 //add-------to support UTF-8     RIO.HTTPWebNode.UseUTF8InHeader := true;  //添加该行,指定采用UTF-8代码传输     RIO.Converter.Encoding:='UTF-8';     RIO.Converter.Options:=RIO.Converter.Options + [soUTF8InHeader,so

XFire调用CXF参数为Null的问题

最近,领导分配了一个任务,做接口联调.情况是这样,对方客户升级了接口采用CXF,而我们还是用的XFire1.2.6,首先就遇到了这个问题:XFire调用CXF参数为Null的问题 . 在网上搜了一大堆资料: http://blog.csdn.net/larry_lv/article/details/6721057 http://ks2144634.blog.163.com/blog/static/133585503201412855556210/ 按照第一个始终还是没能解决,后来找到第二个花了不

MVC5的控制器,使用HttpPost方式时,接收的参数为null的原因

1.问题现象 POST提交时,控制的Action接收到的参数为null, 但Request.Form.Request.Params等集合其实是包含提交的所有数据的 .如下截图: 2.该问题很诡异,重新创建视图.控制器,问题仍然存在: 3.确定控制器肯定是没有问题后,决定首先将视图中的内容清空,发现可以正常接受到参数: 4.每次增加一个HTML元素,加到Model时,发现接收不到参数: 5.确定问题:当Action中的参数名称与提交的数据KEY有相同时(不区分大小写),会导致Action接收不到参

关于后台接收参数为null的问题之ajax--contentType

今天小编遇到一个关于后台接收参数为null的问题之ajax--contentType ? 答: ajax方法中的参数: contentType:发送至服务器时内容的编码类型,一般默认:application/x-www-form-urlencoded(适应大多数的场合) dataType:预期服务器返回的数据类型 有时候前台ajax向后台传数据的时候,能够进到后台,但是后台显示接受的参数为null,如果ajax没有问题,这个时候就要考虑后台在接收参数的时候使用的是什么注解.(@RequestPa

call和apply第一个参数为null/undefined,函数this指向全局对象

call和apply第一个参数为null/undefined,函数this指向全局对象,在浏览器中是window,在node中是global 在严格模式中(ie 6/7/8/9 除外),传入null/undefined,this不指向全局对象,而是null/undefined本身 'use strict' function func(){ console.log(this); } func.call(null); // null func.apply(undefined); // undefin

存储过程输出参数、返回值、返回表及C#调用

存储过程中可以定义输出变量,返回值,执行存储过程还能获得结果集.每个存储过程的默认返回值为0.下面紧接着上文 SQL Server中存储过程Stored Procedure创建及C#调用 基础上写的一个新的Stored Procedure存储过程则包含了输出参数.返回值以及select结果. USE [db] GO /****** Object: StoredProcedure [dbo].[insert_persions] Script Date: 2/25/2015 11:14:11 AM

python中os.path.dirname(__file__) 命令行 参数没有绝对路径导致数据库找不到

(1).当"print os.path.dirname(__file__)"所在脚本是以完整路径被运行的, 那么将输出该脚本所在的完整路径,比如: python d:/pythonSrc/test/test.py 那么将输出 d:/pythonSrc/test (2).当"print os.path.dirname(__file__)"所在脚本是以相对路径被运行的, 那么将输出空目录,比如: python test.py 那么将输出空字符串 启动参数后来加上绝对路径