sql-server – 如果参数为null,如何返回所有记录
发布时间:2021-01-17 07:06:31 所属栏目:MsSql教程 来源:网络整理
导读:以下是我的SP: Alter PROCEDURE GetList (@FromDate date = null,@ToDate date = null)ASSelect * FROM CallList cWhere c.CallDate @FromDate and c.CallDate @ToDate 如果没有通过日期过滤器,我想获得所有记录. 我该怎么办? 解决方法 一些可行的选择: 您
|
以下是我的SP: Alter PROCEDURE GetList ( @FromDate date = null,@ToDate date = null ) AS Select * FROM CallList c Where c.CallDate > @FromDate and c.CallDate < @ToDate 如果没有通过日期过滤器,我想获得所有记录. 我该怎么办? 解决方法一些可行的选择:您可以将@FromDate和@ToDate设置为等于非常早或非常晚的日期,它们分别为NULL. 您可以使用sp_executesql并根据需要构建带有参数的动态查询字符串,例如 DECLARE @Sql NVARCHAR(MAX) = 'SELECT * FROM CallList C WHERE 1 = 1 ' IF @FromDate IS NOT NULL BEGIN SET @Sql += ' AND C.CallDate > @xFromDate' END IF @ToDate IS NOT NULL BEGIN SET @Sql += ' AND C.CallDate < @xToDate' END EXEC sp_executesql @Sql,N'@xFromDate DATETIME,@xToDate DATETIME',@xFromDate = @FromDate,@xToDate = @ToDate 后一种方法比在整个地方使用OR更好,因为包含OR的查询总是最终得到非常好的优化 – 它们可能适用于某些参数集,但通常不是万能的. (编辑:均轻资讯网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- 微软质疑金山公布2003十大安全漏洞权威性
- sql-server – 使用FreeTDS连接到MS SQL Server:错误20002
- sql-server – VB6 ADODB.Recordset RecordCount属性始终返
- 微软对Linux用户展开调查 知己知彼反击对手
- sql – 选择名为“index”的列的表
- 解析sql server的常见文件操作
- sql-server-2008 – 编写SQL查询的最佳方法,该查询检查列是
- sql-server – 限制某些列的更新.仅允许存储过程更新这些列
- sql-server – 从DMV中,你能判断一个连接是否使用了Applica
- 警惕:新病毒Sober 伪装成AV公司的安全装置

