sql - 如何设置日期时间的一部分

标签 sql sql-server datetime

我只需要将日期时间的小时设置为特定值。我知道我可以将它与所需值的差值相加,或者使用原始日期时间的部分创建一个新的日期时间,但是没有更简洁的方法吗?像这样的东西:

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

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

非常感谢。

最佳答案

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';

关于sql - 如何设置日期时间的一部分,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12389084/

相关文章:

php - MySQL 查询多个 LEFT Joins 问题

sql - 联合和排序依据

c# - 如何选择相邻座位?座位表

sql - 这个 SQL 行是说前一天还是第二天?

javascript - Angularjs:使用日期助手格式化 UTC 时间的时间戳

MySQL 查询 - 基于条件的 SELECT

c# - NHibernate 树结构更新根问题

sql - 在Oracle SQL中:如何将当前日期和时间插入表中?

sql-server - 查询 where date = '2016/01/02' 不工作?

sql - 如何以编程方式在字符串前后添加撇号并在其间添加逗号?