KingbaseES timestamp 和 timestamptz 差异比较

本文介绍了KingbaseES数据库中两种时间戳类型——TIMESTAMP和TIMESTAMPTZ的区别。TIMESTAMP不存储时区,其值不会因服务器时区改变而变化;TIMESTAMPTZ则考虑时区,能够正确处理时区转换。两者占用相同存储空间,但TIMESTAMPTZ在处理跨时区数据时更为精确。
摘要由CSDN通过智能技术生成

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值