将 SQL 服务器时区对象 `yyyy-mm-dd HH:MM;SS+HH` 转换为有效的日期时间 (UTC)
Converting a SQL Server Timezone object `yyyy-mm-dd HH:MM;SS+HH` to a valid datetime (UTC)
我有一个日期时间值的字符串表示形式,它有一个偏移量 +03
我假设这意味着 +03 小时,我很可能是错的。
这是我的典型值 table:
2015-05-15 21:35:19+03
只有两个唯一值+3
或+2
我不确定源系统是什么is/was。
我想知道转换这样一个对象的正确方法是什么?我当前的方法是拆分偏移量并将余数转换为日期时间对象并使用 dateadd
添加偏移量
SELECT DATEADD(hour, CAST(value AS int)
, CAST(REPLACE(dt, '+' + value, '') AS DATETIME2)) AS offset_val
, dt
FROM (
VALUES ('2015-05-15 21:35:19+03')
, ('2015-05-15 19:35:19+03')
) t(dt)
CROSS APPLY (
SELECT VALUE
, ROW_NUMBER() OVER (ORDER BY VALUE) AS seq
FROM STRING_SPLIT(t.dt, '+')
) ch
WHERE
seq = 1
+---------------------------+----------------------+
|offset_val |dt |
+---------------------------+----------------------+
|2015-05-16 00:35:19.0000000|2015-05-15 21:35:19+03|
|2015-05-15 22:35:19.0000000|2015-05-15 19:35:19+03|
+---------------------------+----------------------+
你得到的是相反的偏移量,21:35:19+03 是 UTC+3,它代表 UTC 中的 18:35:19。
也就是说,您的字符串表示形式解析得很好 datetimeoffset
然后您可以将其转换为 UTC:
SELECT PARSE('2015-05-15 21:35:19+03' AS datetimeoffset USING 'en-us') AT TIME ZONE 'UTC'
我有一个日期时间值的字符串表示形式,它有一个偏移量 +03
我假设这意味着 +03 小时,我很可能是错的。
这是我的典型值 table:
2015-05-15 21:35:19+03
只有两个唯一值+3
或+2
我不确定源系统是什么is/was。
我想知道转换这样一个对象的正确方法是什么?我当前的方法是拆分偏移量并将余数转换为日期时间对象并使用 dateadd
添加偏移量SELECT DATEADD(hour, CAST(value AS int)
, CAST(REPLACE(dt, '+' + value, '') AS DATETIME2)) AS offset_val
, dt
FROM (
VALUES ('2015-05-15 21:35:19+03')
, ('2015-05-15 19:35:19+03')
) t(dt)
CROSS APPLY (
SELECT VALUE
, ROW_NUMBER() OVER (ORDER BY VALUE) AS seq
FROM STRING_SPLIT(t.dt, '+')
) ch
WHERE
seq = 1
+---------------------------+----------------------+
|offset_val |dt |
+---------------------------+----------------------+
|2015-05-16 00:35:19.0000000|2015-05-15 21:35:19+03|
|2015-05-15 22:35:19.0000000|2015-05-15 19:35:19+03|
+---------------------------+----------------------+
你得到的是相反的偏移量,21:35:19+03 是 UTC+3,它代表 UTC 中的 18:35:19。
也就是说,您的字符串表示形式解析得很好 datetimeoffset
然后您可以将其转换为 UTC:
SELECT PARSE('2015-05-15 21:35:19+03' AS datetimeoffset USING 'en-us') AT TIME ZONE 'UTC'