在 Postgres 中,我试图创建一个具有微秒精度的时间戳字段。
如果我查询可打印格式的时间戳,它会以精确的微秒显示日期,但如果我查询纪元,它只会显示 5 位数字...
示例:
CREATE TABLE date_test (datetime timestamp(6) WITH TIME ZONE);
INSERT INTO date_test VALUES(TO_TIMESTAMP(1525745241.879112));
SELECT datetime FROM date_test; //returns 2018-05-08 12:07:21.879112+10
SELECT EXTRACT(epoch FROM datetime) from date_test; //returns 1525745241.87911
最后一位数字丢失的原因是什么?查询是否固有地转换为 float 并失去准确性?有什么简单的方法可以在 Postgres 中以微秒精度存储日期?
最佳答案
它很丑,但是在头顶上:
t=# select extract(epoch from TO_TIMESTAMP(1525745241.879112) - '1000000000 seconds'::interval)::numeric(20,6) + 1000000000;
?column?
-------------------
1525745241.879112
(1 row)
https://www.postgresql.org/docs/current/static/functions-datetime.html
提取
返回 double
which is 15十进制数字精度,所以微秒不适合...
关于sql - 如何从 Postgres 中的时间戳列获取微秒精度的纪元?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50226454/