将历史日期从utc转换为当地时间

Esp*_*spo 5 sql datetime utc gmt

我有一个包含这样的数据的SQL表:

| theDate (datetime)  | theValue (int) |
----------------------------------------
| 2010-05-17 02:21:10 |              5 |
| 2009-03-12 04:11:35 |             23 |
| 2010-02-19 18:16:53 |             52 |
| 2008-07-07 22:54:11 |             30 |
Run Code Online (Sandbox Code Playgroud)

日期以UTC格式存储在日期时间列中,如何将它们转换为当地时间(挪威)?请记住,由于冬季/夏季,UTC全年的UTC偏移量并不相同.

更新:我正在使用Microsoft SQL Server 2005,我需要从SQL执行此操作,因为数据将在稍后显示给报告.

Ken*_*eth 3

该语句将针对您列出的表起作用。使用该逻辑,您可以将其应用于任何日期字段。

    SELECT CASE
         WHEN [theDate] BETWEEN 
         Convert(DATETIME, Convert(VARCHAR(4), Year([theDate])) + '-03-' + Convert(VARCHAR(2), (31 - (5 * Year([theDate])/4 + 4) % 7)) + ' 02:00:00', 20)
         AND
         Convert(DATETIME, Convert(VARCHAR(4), Year([theDate])) + '-10-' + Convert(VARCHAR(2), (31 - (5 * Year([theDate])/4 + 1) % 7)) + ' 03:00:00', 20)
         THEN Dateadd(hh, 2, [theDate])
         ELSE Dateadd(hh, 1, [theDate])
       END AS [theDate],
       [theValue]
FROM   [YOURTABLE] 
Run Code Online (Sandbox Code Playgroud)