编写此查询以将日期添加到日期的最简洁方法

时间:2012-01-18 18:28:50

标签: sql sql-server

我有一个带有DateTime的字段。我想忽略该字段上的时间并添加指定的小时。

这是我正在寻找的一个例子,其中@h可以是0到23之间的任何值。(为了简单起见,我使用getdate()而不是我的表中的字段)。

declare @h int = 8
select cast(cast(cast(getdate() as date) as nvarchar(50)) + ' ' + CAST(@h as nvarchar(2)) + ':00' as datetime)

我怎样才能更简单地写这个?请记住,我对可读性/可维护性比对速度更感兴趣。

2 个答案:

答案 0 :(得分:6)

SELECT DATEADD(hour, 1, CAST((CAST (GETDATE() as DATE)) as datetime))

您可以根据需要在此处放置参数代替1

答案 1 :(得分:2)

这个怎么样?

declare @h int = 8
select dateadd(hh, @h, cast(cast(getdate() as date) as datetime))