视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
pl/sql获取工作时间(很实用的)
2020-11-09 16:13:35 责编:小采
文档

很实用的获取工作时间 无 create or replace function FUN_GET_WORKTIME(PARAM_DATE IN DATE) return NUMBERisnum_worktime number:= 8;--工作总时长num_mi number:= 60;--60分钟num_ss number:= 60;--60秒num_work_begin number:= 8/24 + 30/(24*60);--8:30n

很实用的获取工作时间
<无> $velocityCount-->
create or replace function FUN_GET_WORKTIME(PARAM_DATE IN DATE) return NUMBER
is
num_worktime number:= 8;--工作总时长
num_mi number:= 60;--60分钟
num_ss number:= 60;--60秒
num_work_begin number:= 8/24 + 30/(24*60);--8:30
num_noon_begin number:= 11/24 + 30/(24*60);--11:30
num_noon_end number:= 12/24;--12:00
num_work_end number:= 17/24;--17:00
num_time number;--时间
num_return number;--返回值
d_init date := to_date('1988-08-08 00:00:00','YYYY-MM-DD hh24:mi:ss'); --初始日期
num_holi NUMBER;
num_holi_y NUMBER;
BEGIN
 --查询节假日表holiday
 select count(1) into num_holi from holiday h where h.holi_day < to_char(PARAM_DATE, 'YYYY-MM-DD');
 select count(1) into num_holi_y from holiday h where h.holi_day = to_char(PARAM_DATE, 'YYYY-MM-DD');
 num_return := floor(PARAM_DATE - d_init - num_holi);
 --判断当天是否为节假日
 if(num_holi_y >= 1) then
 num_return := num_return + 0;
 else
 num_time := PARAM_DATE - to_date(to_char(PARAM_DATE,'YYYY-MM-DD')||' 00:00:00','YYYY-MM-DD hh24:mi:ss');
 --时间在8:30以前至0
 if(num_time<=num_work_begin) then
 num_return := num_return + 0;
 end if;
 --时间在8:30到11:30之间
 if(num_time > num_work_begin and num_time < num_noon_begin) then
 num_return := num_return + (num_time - num_work_begin);
 end if;
 --时间在11:30到12:00之间 
 if(num_time > num_noon_begin and num_time<=num_noon_end) then
 num_return := num_return + (num_noon_begin-num_work_begin);
 end if;
 --时间在12:00到17:00之间
 if(num_time > num_noon_end and num_time<=num_work_end) then
 num_return := num_return + (num_time - num_work_begin - (num_noon_end - num_noon_begin));
 end if; 
 --时间大于17:00
 if(num_time > num_work_end ) then
 num_return := num_return + (num_work_end - num_work_begin - (num_noon_end - num_noon_begin));
 end if; 
 
 
 end if;
 num_return := num_return * num_worktime * num_mi * num_ss;
return (num_return);
end FUN_GET_WORKTIME;

下载本文
显示全文
专题