微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

如何解决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. 将时间戳记存储为字符串。这通常是个坏主意。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。