2013-04-10 3 views
1

У меня есть проблемы с выполнением дат в базе данных Oracle.Устранение неполадок с датой в Oracle

У меня есть запрос:

select 
status, 
id, 
to_char(creationdatetime,'yyyy/mm/dd hh24:mm:ss') as Creation_Time, 
to_char(lastmodificationdatetime,'yyyy/mm/dd hh24:mm:ss') as Last_Mod_Time, 
substr(lastmodificationdatetime - creationdatetime,1,30)*24 as Time_Between, 
--trunc((((86400*(lastmodificationdatetime - creationdatetime))/60)/60)/24) "Days", 
--trunc(((86400*(lastmodificationdatetime - creationdatetime))/60)/60)-24*(trunc((((86400*(lastmodificationdatetime - creationdatetime))/60)/60)/24)) "Hrs", 
--trunc((86400*(lastmodificationdatetime - creationdatetime))/60)-60*(trunc(((86400*(lastmodificationdatetime - creationdatetime))/60)/60)) "Min", 
--trunc(86400*(lastmodificationdatetime - creationdatetime))-60*(trunc((86400*(lastmodificationdatetime - creationdatetime))/60)) "Sec" 
from 
table 
where 
Status='Completed' or Status='Cancelled'; 

(TRUNC является проверка другого способа даты счетов)

Тогда я получаю результаты:

Status  ID CreationDate Lastmodificationdate Time_Between      Days Hours Minutes Seconds 

Completed id1 2013/03/25 12:03:14 2013/03/25 13:03:17 1,78416666666666666666666666648 0 1 47 3 
Completed id2 2013/03/26 09:03:22 2013/03/26 09:03:28 0,45166666666666666666666666656 0 0 27 5 
Cancelled is3 2012/12/19 17:12:50 2012/12/19 19:12:10 1,52222222222222222222222222208 0 1 31 19 
Cancelled id4 2012/12/19 18:12:13 2012/12/19 19:12:23 0,65277777777777777777777777768 0 0 39 10 

Как мы можем видеть даты являются вычитало ошибочно, когда я копирую даты и вычитал их, используя двойные:

select (to_date('2013/03/25 13:03:17', 'yyyy/MM/dd HH24:MI:SS') - 
to_date('2013/03/25 12:03:14', 'yyyy/MM/dd HH24:MI:SS')) 
from dual; 

Я получаю правильные результаты ... Я понятия не имею, что происходит ... Поблагодарили бы за любую помощь.

+0

что делает 'зиЬзЬг (lastmodificationdatetime - creationdatetime, 1,30) * 24'? почему вы не просто уменьшаете их и умножаете на 24, чтобы получить часы? –

+0

Ваш «выбор .. из двойного» не делает то же самое, что и ваш расчет Time_Between. – Rene

ответ

8

Отображаются даты с неправильным форматом.

mm - это месяц, а не минуты. Таким образом, вы повторяете месяц на дисплее времени.

Вы хотите: 'yyyy/mm/dd hh24:mi:ss' (обратите внимание на mi в маске формата)

+1

omg, im so dupid ... thx – Iscario

Смежные вопросы