oracle判定日期是否工作日,ORACLE判断两个日期间隔几个工作日

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;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值