首页  ·  知识 ·  数据库
工作日处理函数(自定义节假日).
佚名  本站原创  MS-SQL  编辑:dezai  图片来源:网络
"COLOR: #0000ff">if "COLOR: #000000"> "COLOR: #808080">exists "COLOR: #000000"> (<
if exists (select * from dbo.sysobjects where id = object_id(N'[tb_Holiday]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
drop table [tb_Holiday]
GO

--定义节假日表
CREATE TABLE tb_Holiday(
HDate
smalldatetime primary key clustered, --节假日期
Name nvarchar(50) not null)             --假日名称
GO

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
   
IF @dt_begin>@dt_end
       
RETURN(DATEDIFF(Day,@dt_begin,@dt_end)
           
+1-(
               
SELECT COUNT(*) FROM tb_Holiday
               
WHERE HDate BETWEEN @dt_begin AND @dt_end))
   
RETURN(-(DATEDIFF(Day,@dt_end,@dt_begin)
       
+1-(
           
SELECT COUNT(*) FROM tb_Holiday
           
WHERE HDate BETWEEN @dt_end AND @dt_begin)))
END
GO

if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[f_WorkDayADD]') and xtype in (N'FN', N'IF', N'TF'))
drop function [dbo].[f_WorkDayADD]
GO

--在指定日期上增加工作天数
CREATE FUNCTION f_WorkDayADD(
@date    datetime--基础日期
@workday int       --要增加的工作日数
)RETURNS datetime
AS
BEGIN
   
IF @workday>0
       
WHILE @workday>0
           
SELECT @date=@date+@workday,@workday=count(*)
           
FROM tb_Holiday
           
WHERE HDate BETWEEN @date AND @date+@workday
   
ELSE
       
WHILE @workday<0
           
SELECT @date=@date+@workday,@workday=-count(*)
           
FROM tb_Holiday
           
WHERE HDate BETWEEN @date AND @date+@workday
   
RETURN(@date)
END
本文作者:佚名 来源:本站原创
CIO之家 www.ciozj.com 微信公众号:imciow
   
免责声明:本站转载此文章旨在分享信息,不代表对其内容的完全认同。文章来源已尽可能注明,若涉及版权问题,请及时与我们联系,我们将积极配合处理。同时,我们无法对文章内容的真实性、准确性及完整性进行完全保证,对于因文章内容而产生的任何后果,本账号不承担法律责任。转载仅出于传播目的,读者应自行对内容进行核实与判断。请谨慎参考文章信息,一切责任由读者自行承担。
延伸阅读