PostgreSQL:在不转换时间的情况下向列添加时区

PostgreSQL: Add timezone to columns without converting the times

我有一个table,有几个时间戳列,基本如下:

         timestamp_utc        |          timestamp
------------------------------------------------------------
'2020-10-28 08:00:00.000'     | '2020-10-28 04:00:00.000'

我知道第一列是UTC时间,第二列是纽约时间。我想知道如何添加各自的时区。所以我想要的结果是这样的:

         timestamp_utc        |          timestamp
------------------------------------------------------------
'2020-10-28 08:00:00.000Z'     | '2020-10-28 04:00:00.000-04'

我试过做这样的事情:

>>> select timestamp_utc AT TIME ZONE 'UTC' from table;

'2020-10-28 04:00:00.000-04' /* wrong */
>>> select timestamp AT TIME ZONE 'EST' from table;

'2020-10-28 05:00:00.000-04' /* wrong, it should be 04:00:00 */

所以终于在纽约部分尝试了这个:

>>> select timestamp_est AT TIME ZONE 'America/New_York' from table;

'2020-10-28 04:00:00.000-04' 

所以我认为当我添加带有位置的时区时,它起作用了。但是,当我尝试使用真正的时区时,除了添加时区外,它还会转换时间?

您不能那样做,因为 PostgreSQL (counter-intuitively) 不会将时区与 timestamp with time zone 一起存储。此数据类型在内部存储为 UTC,显示时根据 timezone 参数的当前设置进行转换。

所以有两种方法可以用时间戳存储时区偏移量:

  1. 添加一个新列 timezone,其中包含作为字符串 (Europe/Vienna) 或数字 (2) 的时区。

  2. 将时间戳存储为字符串。这通常是个坏主意。