10.工作日处理函数(自定义节假日)

10.工作日处理函数(自定义节假日)ifexists(select*fromdbo.sysobjectswhereid=object_id(N'[tb_Holiday]’)andOBJECTPROPERTY(id,N’IsUserTable’)=1)droptable[tb_Holiday]GO定义节假日表CREATETABLEtb_Holiday(HDatesmalldate…

10.工作日处理函数(自定义节假日)"

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

今天的文章10.工作日处理函数(自定义节假日)分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/32584.html

(0)
编程小号编程小号

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注