PostgreSQL:将时区添加到列而不转换时间

问题描述

我有一个带有几个时间戳列的表,基本上如下:

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

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

         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(与直觉相反)没有将时区与timestamp with time zone一起存储。此数据类型内部存储在UTC中,并在显示时根据timezone参数的当前设置进行转换。

因此,可以通过两种方式将时区偏移量与时间戳一起存储:

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

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