SQL语句计算两个日期之间有多少个工作日的方法
发布时间:2020-12-30 20:32:30 所属栏目: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
以上就是本文的全部内容,希望对大家的学习有所帮助。 (编辑:百色站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- SQLServer用存储过程实现插入更新数据示例
- sqlserver中根据字符分割字符串的最好的写法分享
- SQL server 使用 内联结(INNER JOIN) 联结多个表 (以及过滤
- sql里将重复行数据合并为一行数据使用逗号进行分隔
- 如果我们在sql-server中启用read committed snapshot会有什
- SQL Server 2008怎样添加自增列实现自增序号
- SQL Server 2005通用分页存储过程及多表联接应用
- T-sql语句修改SQL Server数据库逻辑名、数据库名、物理名的
- SQL Update多表联合更新的方法
- 在SQL Server 2005所有表中搜索某个指定列的方法