Конвертировать число во время - PullRequest
4 голосов
/ 20 октября 2010

Как преобразовать число 1.33408564814814 во время 32: 01: 05?

Ответы [ 3 ]

7 голосов
/ 20 октября 2010

Если вы действительно хотите получить результат в виде строки символов, вы можете использовать такую ​​функцию:

set serveroutput on format wrapped;

declare
function days_to_time (p_days number) return varchar2
is
  d number := p_days;
  h integer;
  m integer;
  s integer;
begin
  h := trunc(d*24);
  d := d - h/24;
  m := trunc(d*24*60);
  d := d - m/24/60;
  s := round(d*24*60*60);
  return(h||':'||to_char(m,'FM00')||':'||TO_CHAR(s,'FM00'));
end;
begin
  dbms_output.put_line(days_to_time(1.33408564814814));
end;
/

anonymous block completed
32:01:05
6 голосов
/ 20 октября 2010
SELECT
-- EXTRACT(day FROM numtodsinterval(1.33408564814814 , 'DAY')) Days,
EXTRACT(day FROM numtodsinterval(1.33408564814814 , 'DAY')) * 24 + EXTRACT(hour FROM numtodsinterval(1.33408564814814 , 'DAY')) TotalHours,
-- EXTRACT(hour FROM numtodsinterval(1.33408564814814 , 'DAY')) Hours,
EXTRACT(minute FROM numtodsinterval(1.33408564814814 , 'DAY')) Minutes,
EXTRACT(second FROM numtodsinterval(1.33408564814814 , 'DAY')) Seconds
FROM dual;
2 голосов
/ 20 октября 2010

Исходное число - это интервал, выраженный в количестве дней.Следующее немного уродливо, но может помочь показать, что происходит:

SELECT days,
       hours,
       minutes,
       seconds,
       TO_CHAR(days, 'FM9') || ' ' ||
         TO_CHAR(day_hours, 'FM09') || ':' ||
         TO_CHAR(minutes, 'FM09') || ':' ||
         TO_CHAR(seconds, 'FM09') AS interval_string,
       TO_DSINTERVAL(TO_CHAR(days, 'FM9') || ' ' ||
                       TO_CHAR(day_hours, 'FM09') || ':' ||
                       TO_CHAR(minutes, 'FM09') || ':' ||
                       TO_CHAR(seconds, 'FM09')) actual_interval
 FROM (SELECT float_val,
              days, hours, minutes,
              hours - (days * 24) AS day_hours,
              ROUND((((decimal_hours - hours) * 60) - trunc((decimal_hours - hours) * 60)) * 60) AS seconds
      FROM (SELECT float_val,
                   trunc(hours / 24) AS days,
                   decimal_hours,
                   hours,
                   (decimal_hours - hours) * 60 AS decimal_minutes,
                   trunc((decimal_hours - hours) * 60) AS minutes
              FROM (SELECT float_val,
                           float_val * 24 AS decimal_hours,
                           TRUNC(float_val* 24) AS hours
                      FROM (SELECT 1.33408564814814 AS float_val FROM dual))));

Поделитесь и наслаждайтесь.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...