PostgreSQL 的“带有时区的时间戳”数据类型中的时区存储
PostgreSQL 区分时间戳和带有时区的时间戳数据类型。虽然两者都占用 8 个字节,但后者在处理时区信息的方式上呈现出关键区别。
时间戳存储
时间戳数据类型存储确切的时间点作为 UTC 时间戳,没有任何时区信息。然后,根据会话的当前时区设置,向客户端显示此通用时间值。
时区存储在“带有时区的时间戳”
相反,带有时区数据类型的时间戳不存储实际时区。相反,它充当计算存储的 UTC 时间戳的偏移量。读取时,此偏移量用于将存储的 UTC 时间戳转换为查询中指定的时区或当前会话时区。
关键注意事项
相反顾名思义,时区类型的时间戳不存储时区本身。它只是促进 UTC 和本地时区之间的转换。此外,值得注意的是,由于夏令时 (DST),此数据类型可能会出现歧义,从而使其可靠使用受到质疑。
以上是PostgreSQL 的'timestamp with time zone”数据类型实际上是如何存储时区信息的?的详细内容。更多信息请关注PHP中文网其他相关文章!