- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章PostgreSQL timestamp踩坑记录与填坑指南由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
项目Timezone情况 。
NodeJS:UTC+08 。
PostgreSQL:UTC+00 。
1
2
3
4
5
6
7
8
9
10
|
timestampTest.js
const { Client } = require(
'pg'
)
const client = new Client()
client.
connect
()
let sql = ``
client.query(sql, (err, res) => {
console.log(err ? err.stack : res.
rows
[0].datetime)
client.
end
()
})
|
不同时区to_timestamp查询结果 。
测试输入数据为1514736000(UTC时间2017-12-31 16:00:00,北京时间2018-01-01 00:00:00) 。
1、timezone=UTC 。
1
2
3
4
|
BEGIN
;
SET
TIME
ZONE
'UTC'
;
SELECT
to_timestamp(1514736000)
as
datetime;
END
;
|
直接查询:2017-12-31 16:00:00+00YES 。
pg查询:2017-12-31T16:00:00.000ZYES 。
2、timezone=PRC 。
1
2
3
4
|
BEGIN
;
SET
TIME
ZONE
'PRC'
;
SELECT
to_timestamp(1514736000)
as
datetime;
END
;
|
直接查询:2018-01-01 00:00:00+08NO 。
pg查询:2017-12-31T16:00:00.000ZYES 。
PostgreSQL官方文档对timestamp的一个描述 。
详见:8.5.1.3. Time Stamps 。
In a literal that has been determined to be timestamp without time zone, PostgreSQL will silently ignore any time zone indication. That is, the resulting value is derived from the date/time fields in the input value, and is not adjusted for time zone. 。
坑 。
使用to_timestamp进行时间转换且DB时区非UTC时,写入**timestamp without time zone**类型的COLUMN则会与预期结果不符.
不同Timezone/columnType查询结果 。
1、timezone=UTC,timestamp with timezone 。
1
2
3
4
|
BEGIN
;
SET
TIME
ZONE
'UTC'
;
SELECT
TIMESTAMP
WITH
TIME
ZONE
'2017-12-31T16:00:00+00'
as
datetime;
END
;
|
直接查询:2017-12-31 16:00:00+00YES 。
pg查询:2017-12-31T16:00:00.000ZYES 。
2、timezone=UTC,timestamp without timezone 。
1
2
3
4
|
BEGIN
;
SET
TIME
ZONE
'UTC'
;
SELECT
TIMESTAMP
'2017-12-31T16:00:00+00'
as
datetime;
END
;
|
直接查询:2017-12-31 16:00:00YES 。
pg查询:2017-12-31T08:00:00.000ZNO 。
3、timezone=PRC,timestamp with timezone 。
1
2
3
4
|
BEGIN
;
SET
TIME
ZONE
'PRC'
;
SELECT
TIMESTAMP
WITH
TIME
ZONE
'2017-12-31T16:00:00+00'
as
datetime;
END
;
|
直接查询:2018-01-01 00:00:00+08YES 。
pg查询:2017-12-31T16:00:00.000ZYES 。
4、timezone=PRC,timestamp without timezone 。
1
2
3
4
|
BEGIN
;
SET
TIME
ZONE
'PRC'
;
SELECT
TIMESTAMP
'2017-12-31T16:00:00+00'
as
datetime;
END
;
|
直接查询:2017-12-31 16:00:00YES 。
pg查询:2017-12-31T08:00:00.000ZNO 。
据以上结果可判定:
使用pg查询**timestamp without time zone**类型的COLUMN时,会将数据库存储的时间当做北京时间而非UTC时间,与数据库时区没有关系.
总结 。
网上类似问题的解决办法是将DB时区改为UTC+08.
原理:写入DB的时间实际为北京时间,pg库恰好是当做北京时间读取,所以时间戳就不会出问题了.
假如应用部署在不同的地域,使用timestamp without time zone存储timestamp这样的设计简直是灾难.
不要用timestamp without time zone存储timestamp.
不要用timestamp without time zone存储timestamp.
不要用timestamp without time zone存储timestamp.
补充:pg查询时间间隔(timestamp类型) 。
1
|
create_date
timestamp
(6) without
time
zone
|
1.从2015-10-12到2015-10-13 之间的4点到9点的数据 。
1
2
3
4
|
select
*
from
schedule
where
create_date
between
to_date(
'2015-10-12'
,
'yyyy-MM-dd'
)
and
to_date(
'2015-10-13'
,
'yyyy-MM-dd'
)
and
EXTRACT(
hour
from
create_date)
between
4
and
9;
|
结果:
2.2015-10-12五点的数据 。
1
|
select
*
from
schedule
where
hospital_id=
'syzyyadmin'
and
date_trunc(
'hour'
,create_date)=to_timestamp(
'2015-10-12 05'
,
'YYYY-MM-DD HH24'
)
|
结果:
以上为个人经验,希望能给大家一个参考,也希望大家多多支持我。如有错误或未考虑完全的地方,望不吝赐教.
原文链接:https://my.oschina.net/janfon/blog/1795868 。
最后此篇关于PostgreSQL timestamp踩坑记录与填坑指南的文章就讲到这里了,如果你想了解更多关于PostgreSQL timestamp踩坑记录与填坑指南的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我想让我的 NSIS 代码更具可读性。 我需要一些关于明智地编写代码部分的指南(比如 C# 中有 #region #endregion)或任何可以使编写 NSIS 代码变得有趣和容易的信息. 请帮帮我
我正在尝试找出Gherkin中所有可用的语法/格式,例如关于多行参数以及我不知道的所有其他内容。 在挖掘Google搜索结果之后,似乎综合指南位于here中: 我以为那很好,并且it链接到一个页面,该
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 5年前关闭。 Improve thi
当我将 guides 添加到 valueAxesSettings 中时,即使我选择 valueAxesSettings 到 valueAxes 中,它也不起作用。此外,valueAxesSetting
我正在寻找有关如何管理 .NET 程序集的三个不同程序集版本号的指针、建议,甚至是口述。 Product 版本是最简单的,因为这似乎通常由业务决定。然后,文件版本似乎用于部署之间的版本控制,其中实际的
昨晚我脑子里冒出一件事。我想知道为什么我们在项目之间仍然有不同的编码风格。由于风格是个人的东西,我认为最好这样对待它。我们为什么不呢?这有什么技术限制吗? 我举几个例子: // Code sample
我有一个应用程序,用户可以在其中从主 Activity 登录,然后可以使用 ListView 浏览实体的层次结构。因此,Activity 堆栈看起来像这样: A -> B -> B -> B -> .
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 9 年前。 Improve
大家好,上个月我开始学习 CSS。我做的第一件事是阅读我能在 www.w3school.com 上找到的所有内容,之后我开始阅读 CSS Mastery 2nd版本。我已经建立了几个自己的网站并取得了
我希望用户能够上传个人资料图片。 关于如何最好地处理这个问题,是否有任何指导方针?例如 - 在哪里保存图像?和要使用的文件夹结构。- 让用户难以浏览每个人的个人资料照片? 谢谢。 最佳答案 如果你自己
我有兴趣了解有关条件重启系统及其工作原理的更多信息。我不知道从哪里开始。我一直在查看源代码,但想知道是否有更高级别的指南可用。 最佳答案 Kent Pitman:条件系统 http://www.nhp
我想将小型、精简且平均的基于 C 的解析器合并到我的 Android 项目中。我过去做过 JNI 编程,但没有在 Android 上进行任何类型的 native (C) 开发。我的计划是将 C lib
免责声明:我试图搜索类似的问题,但是它返回了关于每个 C++ 问题的信息...此外,我将感谢任何可以提出更好标题的人。 C++ 中有两个著名的循环结构:while 和for。 我故意忽略了 do ..
我一直在尝试批量删除 Wordpress 帖子中的垃圾链接,如下所示: . 它们位于 post_content 列下的 wp_posts 表中。我试图通过在 href 标记中添加 % 的通配符来做到这
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 6 年前。 Improve
我们正在讨论为实体类定义方法的最佳方式 - 作为扩展方法或使用分部类。我们讨论的这类方法不会修改实体的状态,它们是纯粹的“辅助”方法,可以查询状态并返回值。 这两种方法的主要好处是保持实体类干净,同时
您将如何在 Flutter 中在实际屏幕上实现引导层。像这样: 最佳答案 这不是微不足道的。以下是必需的组件: 首先,你必须open a transparent full screen dialog
我们需要通过在 C/C++ 中实现特定算法来解决的大多数科学计算问题都需要远低于 double 的精度。例如,1e-6、1e-7 精度涵盖了 ODE 求解器或数值积分的 99% 情况。即使在我们确实需
我正在研究对专有 UI 框架(用于桌面应用程序)的 RTL 支持,我想知道:是否有关于如何更改小部件渲染的指南? 我正在寻找以下内容的列表: 复选框标签位于复选框左侧,右对齐 工具栏按钮从右到左排列
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
我是一名优秀的程序员,十分优秀!