Преобразовать эпоху в дату в sqlplus / Oracle - PullRequest
12 голосов
/ 29 сентября 2010

У меня есть следующая таблица:

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 из первоначальной формы эпохи? в DD/MM/YYY HH:MI:SS формат в одном запросе в SQLPLUS?

Спасибо!

Ответы [ 2 ]

25 голосов
/ 29 сентября 2010

В Oracle добавление X к DATE вернет вам DATE X дней спустя.

Если 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
0 голосов
/ 30 мая 2017
select ((timestamp_coloum_name - to_date('01-JAN-1970','DD-MON-YYYY')) * (86400)) from any_table;
...