SQL语句计算两个日期之间有多少个工作日的方法
发布时间:2020-12-30 14:28:00 所属栏目:MsSql 来源:互联网
导读:本文的主要内容是用SQL语言计算两个日期间有多少个工作日,需要的朋友可以参考下
/* 1 OR @bdate > @edate
RETURN -1
SELECT @hours =
--如果终止日期与起始日期在同一个星期内,只需要计算有几天即可
CASE WHEN DATEPART(wk,@edate-1)-DATEPART(wk,@bdate) = 0 THEN
CASE WHEN DATEPART(dw,@bdate) > 5 THEN 0
WHEN DATEPART(dw,@edate-1) > 5 THEN 6 - DATEPART(dw,@bdate)
ELSE DATEPART(dw,@edate-1) - DATEPART(dw,@bdate) + 1 END
--如果终止日期与起始日期在不同的星期内
--首先计算出除前后两个星期外完整的星期数 * 5
ELSE (DATEDIFF(dd,@bdate,@edate)
- (8-DATEPART(dw,@bdate))
- DATEPART(dw,@edate-1)) / 7 * 5
--再加上第一个星期里的工作日数
+ CASE WHEN DATEPART(dw,@bdate) < 6 THEN 6 - DATEPART(dw,@bdate)
ELSE 0 END
--加上末一个星期里的工作日数
+ CASE WHEN DATEPART(dw,@edate-1)>5 THEN 5 ELSE DATEPART(dw,@edate-1) END
END * 8
RETURN @hours
END
以上就是本文的全部内容,希望对大家的学习有所帮助。 (编辑:台州站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |