【问题标题】:Convert epoch to date in sqlplus / Oracle在 sqlplus / Oracle 中将纪元转换为日期
【发布时间】:2011-04-18 17:22:01
【问题描述】:

我有下表:

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

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

谢谢!

【问题讨论】:

    标签: oracle datetime date sqlplus epoch


    【解决方案1】:

    在 Oracle 中,将 X 添加到 DATE 将在 X 天后返回 DATE。

    如果 ESTIMATEDENDTIME 是自 Epoch 以来的毫秒数,那么您可以这样做

    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
    

    【讨论】:

    • 该死!这比我尝试的其他解决方案更快、更容易!谢谢!
    【解决方案2】:
    select ((timestamp_coloum_name - to_date('01-JAN-1970','DD-MON-YYYY')) * (86400)) from any_table;
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2016-09-15
      • 1970-01-01
      • 2019-02-19
      • 2018-04-24
      相关资源
      最近更新 更多