B.2. 处理无效或模棱两可的时间戳#
通常,如果日期/时间字符串在语法上有效,但包含超出范围的字段值,则会引发错误。例如,指定 2 月 31 日的输入将被拒绝。
在夏令时转换期间,看似有效的时间戳字符串可能表示不存在或模棱两可的时间戳。此类情况不会被拒绝;通过确定要应用哪个 UTC 偏移量来解决歧义。例如,假设TimeZone参数设置为America/New_York
,请考虑
=> SELECT '2018-03-11 02:30'::timestamptz;
timestamptz
------------------------
2018-03-11 03:30:00-04
(1 row)
由于那天是该时区的春季转换日期,因此没有 2:30AM 的民用时间;时钟从 2AM EST 跳到 3AM EDT。PostgreSQL将给定时间解释为标准时间 (UTC-5),然后显示为 3:30AM EDT (UTC-4)。
相反,考虑回退转换期间的行为
=> SELECT '2018-11-04 01:30'::timestamptz;
timestamptz
------------------------
2018-11-04 01:30:00-05
(1 row)
在该日期,1:30AM 有两种可能的解释;有 1:30AM EDT,然后在时钟从 2AM EDT 跳回 1AM EST 后一小时,有 1:30AM EST。同样,PostgreSQL将给定时间解释为标准时间(UTC-5)。我们可以通过指定夏令时来强制执行其他解释
=> SELECT '2018-11-04 01:30 EDT'::timestamptz;
timestamptz
------------------------
2018-11-04 01:30:00-04
(1 row)
在这些情况下应用的精确规则是,如果一个无效的时间戳似乎落在夏令时跳跃前进的转换范围内,则分配转换前时区中普遍存在的 UTC 偏移,而如果一个模棱两可的时间戳可能落在跳跃后退转换的任一侧,则分配转换后普遍存在的 UTC 偏移。在大多数时区,这等同于说“在有疑问时首选标准时间解释”.
在所有情况下,与时间戳关联的 UTC 偏移都可以明确指定,使用数字 UTC 偏移或对应于固定 UTC 偏移的时区缩写。仅当需要推断偏移量会变化的时区的 UTC 偏移时,才应用刚刚给出的规则。