mysql存储过程工作日判断_mysql存储过程语法 (时间区间工作日,去除节假日)...

该博客介绍了如何使用MySQL存储过程来计算给定时间区间内实际的工作日数量,同时考虑了周末是否为工作日和法定节假日的情况。通过查询配置表获取周末和节假日信息,并结合日期函数进行计算。
摘要由CSDN通过智能技术生成

定义变量:

BEGIN

DECLARE workDays INTEGER;

DECLARE adjustmentDay INTEGER;

DECLARE legalRest INTEGER;

SELECT COUNT(1) INTO adjustmentDay FROM pub_apppar WHERE APR_VALUE >= s AND APR_VALUE <= e AND APR_NAME='周末是工作日的列表';

SELECT COUNT(1) INTO legalRest FROM pub_apppar WHERE APR_VALUE >= s AND APR_VALUE <= e AND APR_NAME='周一至周五为假期参数列表';

select  (floor(days/7)*5

+ days%7

- case when 6 between wd and wd+days%7-1 then 1 else 0 end

- case when 7 between wd and wd+days%7-1 then 1 else 0 end

+ adjustmentDay

- legalRest) as result

INTO workDays

from

(select datediff(e,s)+1 as days, weekday(s)+1 as wd ) as a;

return workDays;

END

子查询

BEGIN

DECLARE workDays INTEGER;

select  (floor(days/7)*5



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值