2

我只需要将日期时间的小时设置为某个值。我知道我可以将它添加到所需值的差异,或者使用原始日期时间的部分创建一个新的日期时间,但是没有更清洁的方法吗?就像是:

declare @d datetime = '09/08/2012 09:14:55'

set @d = SETDATEPARTORSOMETHINGLIKETHAT (hour, @d, 23)

非常感谢。

4

1 回答 1

6
DECLARE @TargetHour TINYINT = 23;

DECLARE @d datetime = '09/08/2012 09:14:55';
SET @d = DATEADD(HOUR, @TargetHour - DATEPART(HOUR, @d), @d);
SELECT @d;

结果:

2012-09-08 23:14:55.000

(是的,如果 @TargetHour小于当前小时,例如 5 或 7,这将起作用。)

我会非常小心使用像 m/d/y 这样的模棱两可和容易出错的格式。恰当的例子:我什至不知道您是指 9 月 8 日还是 8 月 9 日,SQL Server 也不会知道 - 它需要使用区域设置等来弄清楚,如果您将代码提供给设置不同的人,它会产生错误,或者更糟糕的是,默默地接受错误的日期。你应该使用:

DECLARE @d datetime = '2012-09-08T09:14:55';
于 2012-09-12T13:17:26.100 回答