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


    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
  • 相关阅读:
    hdu 4612 Warm up 双连通缩点+树的直径
    Hadoop-04-HBase全然分布式环境搭建
    java实现的Trie树数据结构
    Sharpui企业版-简单介绍【01】 【QQ群:206378966】
    Apache Mina开发手冊之四
    POJ训练计划1459_Power Network(网络流最大流/Dinic)
    svn+ssh
    Android首席设计师宣称移动概念已死,开发人员应该面向屏幕编写应用而非移动
    连锁快餐企业软件的一些管理
    多进程解决datasnap支持的tcp长连接数量少的问题
  • 原文地址:https://www.cnblogs.com/shihao/p/2507466.html
Copyright © 2020-2023  润新知