Re: [HACKERS] What's happened with 1942

Поиск
Список
Период
Сортировка
От Thomas G. Lockhart
Тема Re: [HACKERS] What's happened with 1942
Дата
Msg-id 36E49975.EFD1A0C5@alumni.caltech.edu
обсуждение исходный текст
Ответ на Re: [HACKERS] What's happened with 1942  (Tom Lane <tgl@sss.pgh.pa.us>)
Список pgsql-hackers
> > prova=> select date '1942-01-01' + interval '1 year';
> > ?column?
> > ----------------------
> > 1942-12-31 23:00:00+01  <---------????????????????
> > (1 row)

It is as Tom says:

postgres=> select date '1942-01-01' + interval '1 year';
?column?
----------------------------
Fri Jan 01 00:00:00 1943 GMT
(1 row)

$ setenv PGTZ PST8PDT

postgres=> select date '1942-01-01' + interval '1 year';
?column?
----------------------------
Fri Jan 01 01:00:00 1943 PWT
(1 row)

We seem to have had a timezone adjustment for that year here too. But it
is in your timezone database, not inside of Postgres. Really...

> Thomas would have a better idea about this than I do, but I'm betting 
> that the date-plus-interval operator thinks that a "one year" interval 
> means "365 (or 366 in leap year) times 24 hours", rather than "same 
> local time on the same nominal date next year".  I seem to recall 
> discussions about exactly what "date plus 1 day" means when crossing a 
> daylight-savings-time boundary, for example.

Actually, I'm pretty sure that it adds one to the year in a tm
structure. But Jose's local time zone changed across that year, and the
calculations are done in GMT, then "rotated" back to local time, which
reflects that new zone definition.

You can use zdump to look at the time zone definitions. What time zone
are you using Jose'?
                     - Tom


В списке pgsql-hackers по дате отправления:

Предыдущее
От: Bruce Momjian
Дата:
Сообщение: Re: OUTER joins
Следующее
От: Bruce Momjian
Дата:
Сообщение: Re: [HACKERS] Developers globe