postgres10.2时区研究
搭建两个虚拟环境,操作系统均是cents7。
环境A:
使用timedatectl命令查看时区为 Time zone: Asia/Shanghai (CST, +0800)。
本地数据库时区(show timezone命令)为PRC,等价于cst。
环境B:
时区为America/New_York (EST, -0500),本地数据库时区为US/Eastern,等价于EST。
1. 先针对timestamp with time zone和timestamp without time zone两个配置进行测试。
在环境A的数据库建立数据表并写入数据:
CREAT TABLE test_timestamp(
ttz timestamp with time zone,
twtz timestamp without time zone
);
INSERT INTO test_timestamp VALUES (now(),now());
查看数据:
postgres=# table test_timestamp;
ttz | twtz
-------------------------------+----------------------------
2019-02-15 11:28:26.994804+08 | 2019-02-15 11:28:26.994804
(1 row)
在环境B中,使用python查看:
>>> data = pd.read_sql(''' select * from test_timestamp ''', conn)
>>> data
ttz twtz
0 2019-02-15 03:28:26.994804+00:00 2019-02-15 11:28:26.994804
>>>
会发现ttz字段自动转换成了UTC时间,而twtz字段原封不动的输出。
再测试环境B写入数据:
本地时间为:$ date
Thu Feb 14 22:33:42 EST 2019
执行cur.execute(''' insert into test_timestamp values('2019-02-14 22:33:42','2019-02-14 22:33:42') ''')
在A的数据库中查看:
postgres=# table test_timestamp;
ttz | twtz
-------------------------------+----------------------------
2019-02-15 11:28:26.994804+08 | 2019-02-15 11:28:26.994804
2019-02-14 22:33:42+08 | 2019-02-14 22:33:42
(2 rows)
发现ttz字段日期值加上了环境A的时区,出现了偏差。因为插入语句用的是字符串类型,是的数据库默认为本地时区。
写入数据时如果调用sql函数:
cur.execute(''' insert into test_timestamp values(now(),now()) ''')
在环境A中:
postgres=# table test_timestamp;
ttz | twtz
-------------------------------+----------------------------
2019-02-15 11:28:26.994804+08 | 2019-02-15 11:28:26.994804
2019-02-14 22:33:42+08 | 2019-02-14 22:33:42
2019-02-15 11:41:13.080922+08 | 2019-02-15 11:41:13.080922
(3 rows)
插入的也是环境A的本地时间。也就是说,最后都是以数据库的环境来执行。
结论:
A. 同一时区内,没有差别。跨时区时,如果只是跨时区读(写操作由一个特定时区完成),可以看成是无差别,都需要转换一下,设置成with time zone可能会好一些,因为在读取的时候有些工具或语言(比如java)会自动转成当地时区的时间。如果是跨时区写,那么就要设置成without time zone,要不然数据库记录的时间会有错误,因为写的时候传的是字符串,数据库会加上本地时区。
B. 不同数据库时间类型的名称不一样,postgres里面没有datetime类型,用timestamp表示datetime;在mysql里有datetime类型,也有timestamp类型(含义和postgres里面不一样)。表示的范围大小、是不是带有时区信息也要查看具体数据库的手册。
C. postgres日期类型一般都是“YYYY-MM-DD HH:mm:ss”格式,不接受一般理解上的数字类型的时间戳(int型数值)的输入。时间类型(比如updatetime和tradedate等)的设置不一定得是数值格式,也可以是日期格式,只是需要注意好时区问题。
postgres10.2时区研究的更多相关文章
- tzwhere模块 根据经纬度判断时区
先说一说这个问题的误区: 1: 根据地理常识,我们知道时区有24个,经度/15=商+余数,此时的商就是是时区,给大组长说了一下,不沾边 又过了几天 2:发现django自带的模块timezone,也叫 ...
- fastJSON☞JSONParameters☞时区的修改☞时间最后有一个"Z"
why... 为什么会有这个问题; 由于近期用到需要将数据序列化... 最终选择了fastJSON(版本为1.)来实现. 但是发现了一个问题,表中有一个dateTime类型的字段, 本来数据库中存入的 ...
- Skyfree的毕业论文 《系统封装与部署的深入研究》
Skyfree的毕业论文 <系统封装与部署的深入研究> https://www.itsk.com/thread-197-1-4.html Skyfree 发表于 2007-9-13 07: ...
- 查看/修改 Linux 时间和时区
查看/修改Linux时区和时间 一.时区 1. 查看当前时区 date -R 2. 修改设置时区 方法(1) ...
- rtc关机闹钟5 AlarmManager研究
AlarmManager研究 侯 亮 转自 http://blog.csdn.net/codefly/article/details/17058425 1.概述 在Android系统中,闹钟和唤醒功能 ...
- linux概念之时间与时区
http://www.cnblogs.com/liuyou/archive/2012/07/29/2614338.html Linux时间基准 以上我们了解了RTC(实时时钟.硬件时钟)和OS时钟(系 ...
- 3. 深入研究 UCenter API 之 加密与解密(转载)
1. 深入研究 UCenter API 之 开篇 (转载) 2. 深入研究 UCenter API 之 通讯原理(转载) 3. 深入研究 UCenter API 之 加密与解密(转载) 4. ...
- CST时区,MYSQL与JAVA-WEB服务器时间相差13个小时的问题
最近倒腾了一台阿里云主机,打算在上面装点自己的应用.使用docker安装了安装mysql后,发现数据库的存储的时间与java-web应用的时间差8个小时,初步怀疑是docker容器时区的问题.经过一系 ...
- 世界时区和Java时区详解
0.引言 Druid中时区的问题一直困扰着我们,所以我专门去研究了一下世界时区和Java中的时区,对使用Druid很用帮助. 1.UTC时间&GMT时间 UTC时间是时间标准时间(Univer ...
随机推荐
- LoadRunner 11 安装
下载地址:http://www.ddooo.com/softdown/61971.htm#dltab LoadRunner是一款专业级别的应用负载测试工具,它可以模拟上千万用户对企业应用进行真实的负载 ...
- java对象转化成String类型
在java项目的实际开发和应用中,常常需要用到将对象转为String这一基本功能.本文将对常用的转换方法进行一个总结.常用的方法有Object#toString(),(String)要转换的对象,St ...
- 【node】------module.exports&&exports之间的区别------【巷子】
1.再讲module.exports 与exports之间的区别的时候我们先来回顾一下js里面的引用传递 001.引用传递 var arr = [10,20,30]; var newarr = arr ...
- 其他ip无法访问Yii的gii,配置ip就可以
该文件下的IP ///public $allowedIPs = ['127.0.0.1', '::1']; 修改这里的IP就可以了
- 玩转Javascript this用法
在web项目中Javascript是一门必须要掌握的动态语言,基于Javascript的框架大多离不开不了最基础的Javascript的用法和原理.本文主要是总结一下Javascript中那万恶的th ...
- CentOS7使用yum安装nginx
CentOS默认没有nginx的yum源需要yum安装nginx可以使用一下方法 一,环境检测 二,设置yum源 rpm -Uvh http://nginx.org/packages/centos/7 ...
- poj1185 炮兵阵地【状压DP】
炮兵阵地 Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 32802 Accepted: 12650 Descriptio ...
- Python开发【数据结构】:基础
数据结构 什么是数据结构? 简单来说,数据结构就是设计数据以何种方式组织并存储在计算机中. 比如:列表.集合与字典等都是一种数据结构 N.Wirth: “程序=数据结构+算法” 列表 列表:在其他编程 ...
- Java面试人事篇(二)
1.请你自我介绍一下你自己? 回答提示:一般人回答这个问题过于平常,只说姓名.年龄.爱好.工作经验,这些在简历上都有.其实,企业最希望知道的是求职者能否胜任工作,包括:最强的技能.最深入研究的知识领域 ...
- 【译】Using Objects to Organize Your Code
耗了一个晚上吐血翻译不过也学到了不少...<使用对象来组织你的代码>,翻译中发现原作者在原文中有部分代码有误或不全,本文已修改和添加~ 丽贝卡·墨菲原文链接:http://rmurphey ...