sql-server – 如果参数为null,如何返回所有记录

前端之家收集整理的这篇文章主要介绍了sql-server – 如果参数为null,如何返回所有记录前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
以下是我的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的查询总是最终得到非常好的优化 – 它们可能适用于某些参数集,但通常不是万能的.

猜你在找的MsSQL相关文章