Em floco de Neve, quando a conversão de alguns locais, datas a UTC e, em seguida, de volta para o fuso horário do local usando CONVERT_TIMEZONE função, o resultado final é desativado por uma hora. Por exemplo:
ALTER SESSION SET TIMEZONE = 'Canada/Eastern';
select
cast('1949-04-24' as timestamp) as date_local -- because TIMEZONE = 'Canada/Eastern'
, convert_timezone('Canada/Eastern', 'UTC', '1949-04-24') as date_utc
, convert_timezone('UTC', 'Canada/Eastern', convert_timezone('Canada/Eastern', 'UTC', '1949-04-24')) as date_local1
Os resultados são:
DATE_LOCAL | DATE_UTC | DATE_LOCAL1 |
---|---|---|
1949-04-24 00:00:00.0 | 1949-04-24 05:00:00.0 | 1949-04-24 01:00:00.0 |
Eu espero tanto DATE_LOCAL e DATE_LOCAL1 ser idênticos, no entanto DATE_LOCAL1 é uma hora. É este o esperado? Eu estou faltando alguma coisa ou há um erro no CONVERT_TIMEZONE função?