postgres将子字符串转换为epoch

时间:2017-06-25 18:58:54

标签: sql postgresql substring epoch

我试图将时间戳转换为单个查询中的人类可读时间戳,但我有点卡住了 - 感谢任何帮助。

testing=# SELECT creation_time FROM users LIMIT 1;
    creation_time    
---------------
 1354006445722
(1 row)

testing=# SELECT SUBSTRING('1498123813330', 1,10);
  SUBSTRING  
------------
 1498123813
(1 row)

testing=# SELECT TIMESTAMP WITH TIME ZONE 'epoch' + 1498123813 * INTERVAL '1 second';
        ?column?        
------------------------
 2017-06-22 02:30:13-07
(1 row)

无论如何把它放到一个查询中?

2 个答案:

答案 0 :(得分:1)

你想要的是CAST,即

SELECT TIMESTAMP WITH TIME ZONE 'epoch' +
         SUBSTRING(creation_time, 1, 10)::NUMERIC * INTERVAL '1 second';

但是,如果创建时间是纪元毫秒,你可以这样做:

SELECT to_timestamp(creation_time::double precision / 1000)
相反,它也将保留毫秒。如果需要格式(默认时间戳输出除外),可以使用to_char打印时间戳。

http://rextester.com/EHPNJ86308

答案 1 :(得分:0)

假设created_time存储为varchar,您可以对其应用相同的substring逻辑并将其强制转换为数字:

SELECT TIMESTAMP WITH TIME ZONE 'epoch' + 
       SUBSTRING(creation_time, 1,10)::NUMERIC * INTERVAL '1 second'
FROM   users