在我正在处理的提取中,我有2个datetime列。一列存储日期,另一列存储如下所示的时间。
如何查询表,将这两个字段组合成类型为datetime的1列?
日期
2009-03-12 00:00:00.000
2009-03-26 00:00:00.000
2009-03-26 00:00:00.000
次
1899-12-30 12:30:00.000
1899-12-30 10:00:00.000
1899-12-30 10:00:00.000
在我正在处理的提取中,我有2个datetime列。一列存储日期,另一列存储如下所示的时间。
如何查询表,将这两个字段组合成类型为datetime的1列?
日期
2009-03-12 00:00:00.000
2009-03-26 00:00:00.000
2009-03-26 00:00:00.000
次
1899-12-30 12:30:00.000
1899-12-30 10:00:00.000
1899-12-30 10:00:00.000
当前回答
这对我很有效
CAST(Tbl.date as DATETIME) + CAST(Tbl.TimeFrom AS TIME)
(适用于SQL 2008 R2)
其他回答
找到这个工作的两个日期,你想从一个日期和日期从另一个:
declare @Time as datetime = '2021-11-19 12:34'
declare @Date as datetime = '2021-10-10'
SELECT @time + datediff(day, @Time, @Date)
你可以简单地把两者相加。
如果日期列的时间部分始终为零 时间列的日期部分也始终为零(基准日期:1900年1月1日)
将它们相加将返回正确的结果。
SELECT Combined = MyDate + MyTime FROM MyTable
原理(向ErikE/dnolan致敬)
它是这样工作的,因为日期存储为两个4字节 左4字节为日期,右4字节为日期的整数 4字节是时间。这就像$ 00001 + $ 00000001 = 0001美元0001
编辑关于新的SQL Server 2008类型
日期和时间是SQL Server 2008中引入的类型。如果你坚持添加,你可以使用组合= CAST(MyDate AS DATETIME) + CAST(MyTime AS DATETIME)
关于SQL Server 2008及以上版本的准确性损失的Edit2(向Martin Smith致敬)
看看如何结合日期和时间datetime2在SQL Server?以防止精度损失使用SQL Server 2008及更高。
如果日期列的时间元素和时间列的日期元素都为零,那么Lieven的答案就是您所需要的。如果你不能保证情况总是如此,那么事情就会变得稍微复杂一些:
SELECT DATEADD(day, 0, DATEDIFF(day, 0, your_date_column)) +
DATEADD(day, 0 - DATEDIFF(day, 0, your_time_column), your_time_column)
FROM your_table
DECLARE @Dates table ([Date] datetime);
DECLARE @Times table ([Time] datetime);
INSERT INTO @Dates VALUES('2009-03-12 00:00:00.000');
INSERT INTO @Dates VALUES('2009-03-26 00:00:00.000');
INSERT INTO @Dates VALUES('2009-03-30 00:00:00.000');
INSERT INTO @Times VALUES('1899-12-30 12:30:00.000');
INSERT INTO @Times VALUES('1899-12-30 10:00:00.000');
INSERT INTO @Times VALUES('1899-12-30 10:00:00.000');
WITH Dates (ID, [Date])
AS (
SELECT ROW_NUMBER() OVER (ORDER BY [Date]), [Date] FROM @Dates
), Times (ID, [Time])
AS (
SELECT ROW_NUMBER() OVER (ORDER BY [Time]), [Time] FROM @Times
)
SELECT Dates.[Date] + Times.[Time] FROM Dates
JOIN Times ON Times.ID = Dates.ID
打印:
2009-03-12 10:00:00.000
2009-03-26 10:00:00.000
2009-03-30 12:30:00.000
简单地将两者连接起来,但首先将它们强制转换,如下所示
select cast(concat(Cast(DateField as varchar), ' ', Cast(TimeField as varchar)) as datetime) as DateWithTime from TableName;