- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章PostgreSQL TIMESTAMP类型 时间戳操作由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
PostgreSQL 提供两种存储时间戳的数据类型: 不带时区的 TIMESTAMP 和带时区的 TIMESTAMPTZ.
TIMESTAMP 数据类型可以同时存储日期和时间,但它不存储时区。这意味着,当修改了数据库服务器所在的时区时,它里面存储的值不会改变.
TIMESTAMPTZ 数据类型在存储日期和时间的同时还能正确处理时区。PostgreSQL 使用 UTC 值来存储 TIMESTAMPTZ 数据。在向 TIMESTAMPTZ 字段插入值的时候,PostgreSQL 会自动将值转换成 UTC 值,并保存到表里。当从一个 TIMESTAMPTZ 字段查询数据的时候,PostgreSQL 会把存储在其中的 UTC 值转换成数据库服务器、用户或当前连接所在的时区.
TIMESTAMP 和 TIMESTAMPTZ 都使用8字节存储空间。如下所示:
1
2
3
4
5
6
7
8
9
10
11
12
|
SELECT
typname,
typlen
FROM
pg_type
WHERE
typname ~
'^timestamp'
;
typname | typlen
-------------+--------
timestamp
| 8
timestamptz | 8
(2
rows
)
|
重要提示,TIMESTAMPTZ 并不会存储时区,它只是了 UTC 值,然后会和当前时区进行转换.
。
首先,创建一个含有 TIMESTAMP 和 TIMESTAMPTZ 的表:
CREATE TABLE timestamp_demo (ts TIMESTAMP, tstz TIMESTAMPTZ),
接下来,将数据库服务器的时区设置为 America/Los_Angeles:
SET timezone = 'America/Los_Angeles',
顺便说一句,可以使用 SHOW TIMEZONE 语句来显示当前时区:
SHOW TIMEZONE,
然后,插入一些示例数据:
1
2
3
4
5
6
|
INSERT
INTO
timestamp_demo (ts, tstz)
VALUES
(
'2016-06-22 19:10:25-07'
,
'2016-06-22 19:10:25-07'
);
|
最后,查询:
1
2
3
4
5
6
7
8
|
SELECT
ts
FROM
timestampz_demo;
ts | tstz
---------------------+------------------------
2016-06-22 19:10:25 | 2016-06-22 19:10:25-07
(1 row)
|
再把时区设置为 America/New_York:
SET timezone = 'America/New_York',
再查询一次,结果如下:
1
2
3
4
|
ts | tstz
---------------------+------------------------
2016-06-22 19:10:25 | 2016-06-22 22:10:25-04
(1 row)
|
TIMESTAMP 类型字段的值不变,而 TIMESTAMPTZ 类型字段的值变成了当前时区下的时间.
补充:postgresql timestamp timestamptz 使用注意事项 。
postgresql日期时间类型分为timestamp [ (p) ] [ without time zone ]和timestamp [ (p) ] with time zone,它们的区别在于一个无时区,另一有时区,存储大小均为8字节. 。
同时也要注意time [ (p) ] [ without time zone ]和time [ (p) ] with time zone类型,无时区存储大小为8字节,有时区存储大小为12字节. 。
postgresql中日期时间类型缩写
timestamp 。
timestamptz 。
date (仅年月日部份,存储大小为4字节) 。
time 。
timetz 。
interval(表示间隔,存储大小为16字节) 。
interval可以通过函数make_interval来创建,支持年月星期天小时分钟秒的间隔.如now() + make_interval(days => 10)表示10天后,now() - make_interval(secs => 30)表示30秒之前 。
为保证数据的准确性在保存使用计算过程中应尽量使用timestamptz和timetz,尽量避免使用timestamp和time 。
UTC+8(EAT - 东亚标准时间/中国标准时间(BJT)) 。
注意整个中国使用相同的时区,这就使得这个时区特别的大。在中国最西部的地区,太阳最高的时候是下午3点,在最东部是上午11点。单纯从地理规划来看,整个中国横跨了从东五区(UTC+5)到东九区(UTC+9)共计五个时区.
在postgresql中查询时区的定义 。
select * from pg_timezone_names 。
或查询东亚/中国时区定义 。
select * from pg_timezone_names where utc_offset = '+08:00:00',
查询结果中的"PRC","Asia/Shanghai","Asia/Chongqing"均表示中国 。
生成一个日期时间示例 。
select make_timestamptz(1970,1,1,0,0,0.0,'Asia/Shanghai') 。
注意避免使用timestamp类型相关函数,如:make_timestamp 。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持我。如有错误或未考虑完全的地方,望不吝赐教.
原文链接:https://pg.sjk66.com/ 。
最后此篇关于PostgreSQL TIMESTAMP类型 时间戳操作的文章就讲到这里了,如果你想了解更多关于PostgreSQL TIMESTAMP类型 时间戳操作的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
给定一个带有多个 date_time 戳的字符串,我想 提取第一个戳及其前面的文本 候选字符串可以有一个或多个时间戳 后续的 date_time 戳记将被 sep="-" 隔开 后续date_time
是否可以合并从相机拍摄的文本和照片?我想在照片上标记日期和时间,但我在 Google 上找不到任何内容。 最佳答案 使用下面的代码来实现你所需要的。 Bitmap src = Bitm
有没有办法通过 Graph API 戳另一个用户?基于this post ,并使用 Graph Explorer ,我发布到“/USERID/pokes”,我已经授予它(Graph API 应用程序和
我有两个向左浮动的元素。一个是 body 的第一个 child ,另一个是容器的第一个 child ,容器是 body 的第二个 child 。 ...
我是一名优秀的程序员,十分优秀!