Конвертировать исторические даты из utc в местное время - PullRequest
5 голосов
/ 20 мая 2010

У меня есть таблица 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 |

Даты хранятся в формате UTC в столбце даты и времени, как я могу преобразовать их в местное время (Норвегия)? Помните, что смещение UTC не одинаково в течение всего года из-за зимы / лета.

ОБНОВЛЕНИЕ : Я использую Microsoft SQL Server 2005, и мне нужно сделать это из SQL, потому что данные будут показаны в отчете позже.

Ответы [ 4 ]

3 голосов
/ 20 мая 2010

Это утверждение будет работать против таблицы, которую вы перечислили. Используя логику, вы можете применить ее к любым полям даты.

    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] 
2 голосов
/ 27 января 2012

Напишите вам функцию CLR, которая преобразует ваш SqlDateTime из UTC в ваш локальный CLR, что-то вроде этого:

[Microsoft.SqlServer.Server.SqlFunction]
public static SqlDateTime ToLocalTime(SqlDateTime dt)
{
    try
    {
         return TimeZone.CurrentTimeZone.ToLocalTime(dt.Value);
    }
    catch
    {
        return SqlDateTime.Null;
    }
}
0 голосов
/ 11 мая 2016

вот моя функция - возвращать местное зимнее время из местного времени

на основе изменения времени в последнее воскресенье марта в 2:00 и в последнее воскресенье октября в 3:00

use your_DB
go
CREATE function [dbo].[ConvertToLocalWinterTime](@instime datetime)
returns datetime
as
begin
declare @localtm datetime = @instime
declare @localwintertm datetime
declare @lastmarchsunday datetime
declare @lastoctobersunday datetime
declare @tmpmd datetime = '03.31.' + convert(char(4),year(@localtm))
declare @tmpod datetime = '10.31.' + convert(char(4),year(@localtm))

    --- last sunday in march
    declare  @DOFWEEKM int = datepart (weekday,@tmpmd-1) 
    if @DOFWEEKM <7
    begin
    set @lastmarchsunday = @tmpmd - @DOFWEEKM 
    end
    else 
    begin
    set @lastmarchsunday = @tmpmd 
    end
    ----last sunday in October
    declare  @DOFWEEKO int = datepart (weekday,@tmpod-1) 
    if @DOFWEEKO <7
    begin
    set @lastoctobersunday = @tmpod - @DOFWEEKO
    end
    else 
    begin
    set @lastoctobersunday = @tmpod
    end
    -------------------------------
    if (@localtm > dateadd(hh,2,@lastmarchsunday)) and (@localtm < dateadd(hh,3,@lastoctobersunday))
    begin
    set @localwintertm =  dateadd(hh,-1, @localtm)
    end
    else 
    begin
    set @localwintertm = @localtm
    end

return @localwintertm
end
0 голосов
/ 20 мая 2010

Использование PHP, если вы можете ...

$dateFormat = 'r';
$tz         = 'Australia/Perth';
function convertDate($epochDate) {
  global $dateFormat, $tz;
  $tzOld = getenv("TZ");
  putenv("TZ=$tz");
  $ret = date($dateFormat, ($epochDate*1));
  putenv("TZ" . ($tzOld ? "=$tzOld" : ""));
  return $ret;
}
...