create or replace function add_times(d1 in date,newtime in date) return date is hh number; mm number; ss number; hours number; dresult date; begin -- 下面依次取出时、分、秒 select to_number(to_char(newtime,'hh24')) into hh from dual; select to_number(to_char(newtime,'mi')) into mm from dual; select to_number(to_char(newtime,'ss')) into ss from dual; -- 换算出newtime中小时总和,在一天的百分几 hours := (hh + (mm / 60) + (ss / 3600))/ 24; -- 得出时间相加后的结果 select d1 + hours into dresult from dual; return(dresult); end add_times;
-- 测试用例 -- select add_times(sysdate,to_date('2004-12-06 03:23:00','yyyy-mm-dd hh24:mi:ss')) from dual