9

我有一个值为 2013-03-22 15:19:02.000 的“日期时间”列

我需要将此值转换为纪元时间并将其存储在“bigint”字段中

上述时间的实际纪元值是1363945741898,,当我使用

  select DATEDIFF(s, '1970-01-01 00:00:00', '2013-03-22 15:19:02.000')

我得到1363965542,,当我使用

select DATEDIFF(ms, '1970-01-01 00:00:00', '2013-03-22 15:19:02.000')

我明白了,

消息 535,级别 16,状态 0,第 1 行 datediff 函数导致溢出。分隔两个日期/时间实例的日期部分的数量太大。尝试将 datediff 与不太精确的日期部分一起使用。

如何从“日期时间”字段中获取准确的纪元值

我使用 SQL Server 2008。这也适用于 2005。

4

4 回答 4

12

这是一个未经测试的示例,由徒手编写:)

declare @v_Date datetime
set @v_Date = '2013-03-22 15:19:02.000'

declare @v_DiffInSeconds integer
declare @v_DiffInMSeconds bigint

select @v_DiffInSeconds = DATEDIFF(s, '1970-01-01 00:00:00', @v_Date)
select @v_DiffInMSeconds = cast(@v_DiffInSeconds as bigint) * 1000 + cast(DATEPART(ms, @v_Date) as bigint)

编辑 我在下面做了这个例子来说明时区转换。给定的时间戳(以秒为单位,我删除了最后三位数字“898”)在这里通过添加 5.5 小时(19800 秒)转换为本地 IST 时区,然后我将其从本地时间转换回时间戳再次格林威治标准时间。以下计算与问题中的值匹配(以秒为单位)。

declare @v_time datetime
set @v_time = '1970-01-01 00:00:00'

declare @v_date datetime
set @v_date = '2013-03-22 15:19:01'

-- This returns "March, 22 2013 15:19:01"
select dateadd(s, (1363945741 + 19800), @v_time)

-- This returns "1363945741"
select datediff(s, @v_time, @v_date) - 19800
于 2013-03-26T11:13:03.517 回答
3

当试图获得精确的毫秒数时,我们会得到溢出异常。我们可以得到直到秒的值并乘以 1000。

这相当于new Date().getTime()在 javascript 中:

使用以下语句以秒为单位获取时间。

SELECT cast(DATEDIFF(s, '1970-01-01 00:00:00.000', '2016-12-09 16:22:17.897' ) as bigint)

使用以下语句以毫秒为单位获取时间。

SELECT cast(DATEDIFF(s, '1970-01-01 00:00:00.000', '2016-12-09 16:22:17.897' ) as bigint) * 1000

使用以下语句将纪元转换为人类可读的日期时间:

select DATEADD(s, 1481300537, '1970-01-01 00:00:00')
于 2016-12-12T19:56:34.180 回答
1

纪元到日期时间

create function [dbo].[EpochToDate](@Date bigint)
returns datetime
begin
    return (select dateadd(s, @Date, '19700101'))
end 
于 2019-08-05T10:59:21.680 回答
0

使用下面的代码从纪元时间获取人类可读的日期

select DATEADD(s,convert(bigint,@date)/2, DATEADD(s, convert(bigint,@date)/2, '1970-01-01 00:00:00'))
于 2020-11-13T10:52:10.647 回答