gpt4 book ai didi

MSSQL 计算两个日期相差的工作天数的语句

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 30 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章MSSQL 计算两个日期相差的工作天数的语句由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

代码如下

if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[f_WorkDay]') and xtype in (N'FN', N'IF', N'TF'))  drop function [dbo].[f_WorkDay]  GO  --计算两个日期相差的工作天数  CREATE FUNCTION f_WorkDay(  @dt_begin datetime, --计算的开始日期  @dt_end datetime --计算的结束日期  )RETURNS int  AS  BEGIN  declare @i int  select @i=abs(datediff(dd,@dt_begin,@dt_end))  declare @t table(dt datetime)  if @dt_begin>@dt_end  insert @t select dateadd(dd,number,@dt_end) from master..spt_values  where number<=@i and type='P'  else  insert @t select dateadd(dd,number,@dt_begin) from master..spt_values  where number<=@i and type='P'  return(select count(*) from @t where (datepart(weekday,dt)+@@datefirst-1)%7 between 1 and 5)  END  GO  select dbo.f_WorkDay('2009-10-10','2009-10-1')  /*  -----------  7  (1 個資料列受到影響)  */  if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[f_WorkDay]') and xtype in (N'FN', N'IF', N'TF'))  drop function [dbo].[f_WorkDay]  GO  --计算两个日期相差的工作天数  CREATE FUNCTION f_WorkDay(  @dt_begin datetime, --计算的开始日期  @dt_end datetime --计算的结束日期  )RETURNS int  AS  BEGIN  DECLARE @workday int,@i int,@bz bit,@dt datetime  set @workday=0  IF @dt_begin>@dt_end  SELECT @bz=1,@dt=@dt_begin,@dt_begin=@dt_end,@dt_end=@dt  ELSE  SET @bz=0  WHILE @dt_begin<=@dt_end  BEGIN  SELECT @workday=CASE  WHEN (@@DATEFIRST+DATEPART(Weekday,@dt_begin)-1)%7 BETWEEN 1 AND 5  THEN @workday+1 ELSE @workday END,  @dt_begin=@dt_begin+1  END  RETURN(CASE WHEN @bz=1 THEN -@workday ELSE @workday END)  END  GO  select dbo.f_WorkDay('2009-10-10','2009-10-1')  /*  -----------  -7  */  。

最后此篇关于MSSQL 计算两个日期相差的工作天数的语句的文章就讲到这里了,如果你想了解更多关于MSSQL 计算两个日期相差的工作天数的语句的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com