CreateTime--2017年9月7日17:14:56

Author:Marydon

ORACLE判断两个日期间隔几个工作日

方法:使用存储过程

/**

* 判断两个日期间隔几个工作日

*/

CREATE OR REPLACE FUNCTION "FUN_BETWEENDAYS"(start_dt date, end_dt date)

RETURN INT IS

t_days INT;

BEGIN

SELECT (TRUNC(end_dt - start_dt) - ((CASE

WHEN (8 - to_number(to_char(start_dt, 'D'))) >

TRUNC(end_dt - start_dt) + 1 THEN

0

ELSE

trunc((TRUNC(end_dt - start_dt) -

(8 - to_number(to_char(start_dt, 'D')))) / 7) + 1

END) + (CASE

WHEN MOD(8 - to_char(start_dt, 'D'), 7) >

TRUNC(end_dt - start_dt) - 1 THEN

0

ELSE

TRUNC((TRUNC(end_dt - start_dt) -

(MOD(8 - to_char(start_dt, 'D'), 7) + 1)) / 7) + 1

END)))

INTO t_days

FROM dual;

RETURN t_days;

END FUN_BETWEENDAYS;

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐