Code highlighting produced by Actipro CodeHighlighter (freeware)-->去掉法定节假日(周六,周天)和指定节假日
USE [DBName]
GO
/****** 对象: Table [dbo].[T_SYS_Holiday] 脚本日期: 11/08/2010 16:04:27 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
SET ANSI_PADDING ON
GO
CREATE TABLE [dbo].[T_SYS_Holiday](
[id] [int] IDENTITY(,) NOT NULL,
[name] [varchar]() COLLATE Chinese_PRC_CI_AS NOT NULL,
[Hdate] [datetime] NOT NULL,
[isholiday] [varchar]() COLLATE Chinese_PRC_CI_AS NOT NULL,
CONSTRAINT [PK_T_SYS_Holiday] PRIMARY KEY CLUSTERED
(
[id] ASC
)WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY]
) ON [PRIMARY] GO
SET ANSI_PADDING OFF 表记录示例:
国庆节 -- :: 节假日
国庆补班 -- :: 非节假日
国庆补班 -- :: 非节假日
国庆 -- :: 节假日
国庆 -- :: 节假日
国庆 -- :: 节假日
国庆 -- :: 节假日
国庆 -- :: 节假日
国庆 -- :: 节假日
中秋补班 -- :: 非节假日
中秋补班 -- :: 非节假日
中秋 -- :: 节假日
中秋 -- :: 节假日
中秋 -- :: 节假日 --计算实际工作日(单位:天)
create FUNCTION [dbo].[fn_WorkDay](
@dt_begin datetime, --计算的开始日期
@dt_end datetime --计算的结束日期
)RETURNS int
AS
BEGIN
DECLARE @workday int,@bz bit,@dt datetime
IF @dt_begin> @dt_end
SELECT @bz=,@dt=@dt_begin,@dt_begin=@dt_end,@dt_end=@dt
ELSE
SET @bz=
set @workday=
WHILE @dt_begin+<=@dt_end
BEGIN
SELECT @workday=CASE
WHEN ((((@@DATEFIRST+DATEPART(Weekday,@dt_begin)-)% BETWEEN AND )or @dt_begin in(
select Hdate from t_sys_holiday where isholiday='非节假日'
))
and (@dt_begin not in(select Hdate from t_sys_holiday where isholiday='节假日')))
THEN @workday+ ELSE @workday END,
@dt_begin=@dt_begin+
END
RETURN(CASE WHEN @bz= THEN -@workday ELSE @workday END)
END --计算实际工作时间(单位:小时)
create FUNCTION [dbo].[fn_WorkHour](
@dt_begin datetime, --计算的开始日期
@dt_end datetime --计算的结束日期
)RETURNS int
AS
BEGIN
DECLARE @workhour int,@workday int,@bz bit,@dt datetime ,@memorybegin_dt datetime
IF @dt_begin> @dt_end
SELECT @bz=,@dt=@dt_begin,@dt_begin=@dt_end,@dt_end=@dt
ELSE
SET @bz=
set @workhour=
SET @workday=
SET @memorybegin_dt=@dt_begin
WHILE dateadd(hh,,dateadd(hh,,@dt_begin))<=@dt_end
BEGIN
SELECT @workhour=CASE
WHEN ((((@@DATEFIRST+DATEPART(Weekday,@dt_begin)-)% BETWEEN AND )or @dt_begin in(
select Hdate from t_sys_holiday where isholiday='非节假日'
)) and (@dt_begin not in(select Hdate from t_sys_holiday where isholiday='节假日')))
THEN @workhour+ ELSE @workhour END
set @dt_begin=dateadd(hh,,dateadd(hh,,@dt_begin))
END
set @workhour=@workhour--datediff(hh,@memorybegin_dt+@workday,@dt_end)
RETURN(CASE WHEN @bz= THEN -@workhour ELSE @workhour END)
END select dbo.fn_WorkDay('2010-11-04 09:09:09','2010-11-05 09:09:09') --
select dbo.fn_WorkDay('2010-11-04 09:09:09','2010-11-06 09:09:09') --
select dbo.fn_WorkDay('2010-11-04 09:09:09','2010-11-07 09:09:09') --
select dbo.fn_WorkDay('2010-11-04 09:09:09','2010-11-08 09:09:09') -- select dbo.[fn_WorkHour]('2010-11-04 09:09:09','2010-11-05 09:09:09')--
select dbo.[fn_WorkHour]('2010-11-04 09:09:09','2010-11-06 09:09:09')--
select dbo.[fn_WorkHour]('2010-11-04 09:09:09','2010-11-07 09:09:09')--
select dbo.[fn_WorkHour]('2010-11-04 09:09:09','2010-11-08 09:09:09')--

SQL计算实际工作日(天)及两个时间(工作日)间隔(小时)!的更多相关文章

  1. javascript中计算两个时间日期间隔的天数

    <script>              /*                  计算两个日期的时间间隔天数              */              //时间字符串的格 ...

  2. winform timespan 两个时间的间隔(差) 分类: WinForm 2014-04-15 10:14 419人阅读 评论(0) 收藏

    TimeSpan 结构  表示一个时间间隔. 先举一个小例子:(计算两个日期相差的天数) 代码如下: DateTime dt = DateTime.Now.ToShortDateString(yyyy ...

  3. GoLang 获取两个时间相差多少小时

    package main import ( "fmt" "time" ) func main() { fmt.Println(getHourDiffer(&qu ...

  4. js前台计算两个日期的间隔时间(时间差)

    在后台传来两个时间字段,从中解析出两个字符串类型的日期格式 需要在前台解析出两个时间的间隔 这里采用获取两个日期的时间戳进行计算 时间戳是指格林威治时间1970年01月01日00时00分00秒(北京时 ...

  5. js前台计算两个日期的间隔时间

    js前台计算两个日期的间隔时间(时间差)原创 2017年08月28日 16:09:43 标签:javascript 1144在后台传来两个时间字段,从中解析出两个字符串类型的日期格式 需要在前台解析出 ...

  6. java 判断两个时间相差的天数

    1.实现目标 输入:两个日期 输出:两个日期相差的天数 2.代码实现 方法1: 通过Calendar类的日期比较.注意:这里需要考虑一下: 日期是跨年份的,如一个是2012年,一个是2015年的   ...

  7. C#两个时间的时间差的方法

    今天遇到一问题,计算两个时间的时间差,看网上的写法较为复杂,找到个简单点的,记录下作为自己的总结. 关键函数: DateTime.Subtract 函数解释: 从此实例中减去指定的日期和时间,返回一个 ...

  8. Java判断两个时间相差的天数

    1.实现目标 输入:两个日期 输出:两个日期相差的天数 2.代码实现 方法1: 通过Calendar类的日期比较.注意:这里需要考虑一下: 日期是跨年份的,如一个是2012年,一个是2015年的   ...

  9. java判断两个时间相差得天数

    方法一:通过Calendar类得日期比较,在这需要考虑闰年和平年,也要考虑跨年份 /** * date2比date1多的天数 * @param date1 * @param date2 * @retu ...

  10. 【HANA系列】SAP HANA SQL计算两个日期的差值

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[HANA系列]SAP HANA SQL计算两个 ...

随机推荐

  1. javascript中关于坐标 大小 的描述

    window对象 有效桌面的大小,除去桌面下面的任务栏的高度 window.screen.availHeight : window.screen.availWidth :   浏览器窗口的左上角相对于 ...

  2. iOS16进制设置颜色

    UIColor+Hex.h // // UIColor+Hex.h // 16进制颜色类别 // // Created by apple on 15-4-3. // Copyright (c) 201 ...

  3. login shell 和 non-login shell 的区别

    介绍之前先思考一个问题:有时我们通过su命令切换用户后,却发现并没有进入该用户的shell环境.这是为什么? login shell:取得bash时需要完整的登录流程.就是说通过输入账号和密码登录系统 ...

  4. ExtJs之Ext.each

    <!DOCTYPE html> <html> <head> <title>ExtJs</title> <meta http-equiv ...

  5. hdu 4628(状态压缩)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4628 思路:首先把所有的回文找出来,如果当前状态为回文,则dp[state]=1,否则dp[state ...

  6. 集成 Tomcat 插件到 Eclipse 的过程

    Java代码: . 下载 Tomcat Tomcat6,下载地址:http://tomcat.apache.org/download-60.cgi,选择绿色版的 zip 进行下载(目前最新的 Tomc ...

  7. Java:内部类

    1.内部类的定义: 一个内部类可以定义在另一个类里,可以定义在函数里,甚至可以作为一个表达式的一部分. 2.内部类的分类: Java中的内部类共分为四种: 成员内部类member inner clas ...

  8. JavaPersistenceWithHibernate第二版笔记-第五章-Mapping value types-001Mapping basic properties(@Basic、@Access、access="noop"、@Formula、@ColumnTransformer、@Generated、 @ColumnDefaul、@Temporal、@Enumerated)

    一.简介 在JPA中,默认所有属性都会persist,属性要属于以下3种情况,Hibernate在启动时会报错 1.java基本类型或包装类 2.有注解 @Embedded 3.有实现java.io. ...

  9. [iOS]iPhone推送原理

    推送原理,先上图 说一下原理吧, 由App向iOS设备发送一个注册通知 iOS向APNs远程推送服务器发送App的Bundle Id和设备的UDID APNs根据设备的UDID和App的Bundle ...

  10. Sqlstate解释

    本篇文章主要介绍了"Sqlstate详解",主要涉及到方面的内容,对于DB2感兴趣的同学可以参考一下: 根据 X/Open 和 SQL Access Group SQL CAE 规 ...