您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

Oracle查询以获取两个日期之间的工作日数,不包括节假日

Oracle查询以获取两个日期之间的工作日数,不包括节假日

采取之前的答案中的代码,并将其从函数转换为查询,可以得到:

CREATE TABLE Holidays ( HolidayDates ) AS
SELECT DATE '2018-12-25' FROM DUAL UNION ALL
SELECT DATE '2018-12-31' FROM DUAL;

CREATE TABLE table_name ( start_date, end_date ) AS
SELECT DATE '2018-12-21', DATE '2018-12-26' FROM DUAL UNION ALL
SELECT DATE '2018-12-28', DATE '2019-01-01' FROM DUAL;

SELECT t.*,
       ( TRUNC( end_date, 'IW' ) - TRUNC( start_date, 'IW' ) ) * 5 / 7
       + LEAST( TRUNC( end_date   ) - TRUNC( end_date,   'IW' ) + 1, 5 )
       - LEAST( TRUNC( start_date ) - TRUNC( start_date, 'IW' ), 5 )
       - ( SELECT COUNT(1)
           FROM   holidays
           WHERE  HolidayDates BETWEEN t.start_date AND t.end_date
           -- Exclude any weekend holidays so we don't double count.
           AND    TRUNC( HolidayDates ) - TRUNC( HolidayDates, 'IW' ) <= 5
         )
       AS Num_Week_Days
FROM   table_name t;

START_DATE | END_DATE  | NUM_WEEK_DAYS
:--------- | :-------- | ------------:
21-DEC-18  | 26-DEC-18 |             3
28-DEC-18  | 01-JAN-19 |             2
01-JAN-19  | 07-JAN-19 |             5

db <>在这里拨弄

Oracle 2022/1/1 18:53:30 有528人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶