KingbaseES timestamp 和 timestamptz 差异比较
KingbaseES 提供两种存储时间戳的数据类型: 不带时区的 TIMESTAMP 和带时区的 TIMESTAMPTZ。
- TIMESTAMP 数据类型可以同时存储日期和时间,但它不存储时区。这意味着,当修改了数据库服务器所在的时区时,它里面存储的值不会改变。
- TIMESTAMPTZ 数据类型在存储日期和时间的同时还能正确处理时区。在向 TIMESTAMPTZ 字段插入值的时候,KES 默认认为时间是当前时区。当插入的数据是非当前时区时,KES 会把存储在其中的值转换成数据库服务器 TIMEZONE 参数所在的时区。
TIMESTAMP 和 TIMESTAMPTZ 都使用8字节存储空间。例子如下:
INSERT INTO tz_test(ts, tstz) VALUES('2016-06-22 19:10:25', '2016-06-22 19:10:25' ); INSERT INTO tz_test(ts, tstz) VALUES(sysdate, sysdate ); INSERT INTO tz_test(ts, tstz) VALUES('2016-06-22 19:10:25-07', '2016-06-22 19:10:25-07' ); test=# select * from tz_test; ts | tstz ---------------------+------------------------ 2016-06-22 19:10:25 | 2016-06-22 19:10:25+08 2021-01-06 21:31:04 | 2021-01-06 21:31:04+08 2016-06-22 19:10:25 | 2016-06-23 10:10:25+08 test=# show timezone; TimeZone --------------- Asia/Shanghai
KINGBASE研究院