如何解决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
参数的当前设置进行转换。
因此,可以通过两种方式将时区偏移量与时间戳一起存储:
-
添加新列
timezone
,其中包含时区作为字符串(Europe/Vienna
)或数字(2
)。 -
将时间戳记存储为字符串。这通常是个坏主意。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。