sql中如何计算得到一段时间内指定日期中有多少个休息日和节假日

2025-05-08 21:18:37
推荐回答(1个)
回答1:

这个问题的前题是需要建立一个表(存放休息日和节假日) holidays,里面存放了所有休息日等
SQL中提供了一些日期计算函数如dateadd,可对日期进行递增操作。
基本代码如下:
declare @startdate datetime='2015-9-10'
declare @enddate datetime='2015-10-10'
declare @days int=0
set @startdate=dateadd(day,@startdate,1) --给开始日期加1天
while(@startdate<@enddate) --如果小于结束日期,一直循环处理下面
begin
IF EXISTS (SELECT * FROM holidays WHERE holiday=@startdate) --如果假日表中找到对应日期,则假日数加1
set @days=@days+1

set @startdate=dateadd(day,@startdate,1) --给开始日期加1天
end

select @days --总天数。