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
参数的当前设置进行转换。
所以有两种方法可以用时间戳存储时区偏移量:
添加一个新列 timezone
,其中包含作为字符串 (Europe/Vienna
) 或数字 (2
) 的时区。
将时间戳存储为字符串。这通常是个坏主意。
我有一个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
参数的当前设置进行转换。
所以有两种方法可以用时间戳存储时区偏移量:
添加一个新列
timezone
,其中包含作为字符串 (Europe/Vienna
) 或数字 (2
) 的时区。将时间戳存储为字符串。这通常是个坏主意。