加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程 > 正文

sql-server – 假如参数为null,怎样返回全部记录

发布时间:2021-01-17 04:58:59 所属栏目:编程 来源:网络整理
导读:以下是我的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的查询老是最终获得很是好的优化 – 它们也许合用于某些参数集,但凡是不是全能的.

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读