在sqlplus / Oracle中将epoch转换为日期

12

我有以下表格:

SQL> desc recording
 Name                 Null?    Type
 -------------------- -------- ------
 CAPTUREID            NOT NULL NUMBER(9)
 STARTDATE            NOT NULL DATE
 ENDDATE                       DATE
 STATE                         NUMBER(1)
 ESTIMATEDENDTIME              NUMBER(13)

这是一个表格的单行代码:

SQL> select * from recording where CAPTUREID=14760457;

 CAPTUREID STARTDATE           ENDDATE             STATE ESTIMATEDENDTIME
---------- ------------------- ------------------- ----- ----------------
  14760457 29/09/2010 08:50:01 29/09/2010 09:52:04     0    1285746720000

我很确定这个问题之前已经被问过很多次,但是到目前为止我找到的所有解决方案都没有真正起作用,那么...我该如何在SQLPLUS中的单个查询中将ESTIMATEDENDTIME从其原始的epoch形式转换为DD/MM/YYY HH:MI:SS格式?

谢谢!

2个回答

25

在Oracle中,将X添加到日期将返回X天后的日期。

如果ESTIMATEDENDTIME是自纪元以来的毫秒数,则可以执行以下操作:

DATE '1970-01-01' + ( 1 / 24 / 60 / 60 / 1000) * ESTIMATEDENDTIME

然后使用to_char函数来达到所需的日期格式,例如:

SELECT 
  captureid
, startdate
, enddate
, state
, estimatedendtime
, DATE '1970-01-01' + ( 1 / 24 / 60 / 60 / 1000) * estimatedendtime AS estimatedenddate
FROM recording

该死!这比我尝试的其他解决方案更快更容易!谢谢! - Oink

0
select ((timestamp_coloum_name - to_date('01-JAN-1970','DD-MON-YYYY')) * (86400)) from any_table;

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接