将数字转换为时间

问题描述 投票:4回答:3

如何将号码1.33408564814814转换成时间32:01:05?

sql oracle
3个回答
7
投票

如果您确实希望将结果作为字符串,则可以使用如下函数:

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
投票
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
投票

原始数字是以天数表示的间隔。以下有点难看但可能有助于显示正在发生的事情:

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))));

分享和享受。

© www.soinside.com 2019 - 2024. All rights reserved.