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. .NET设计模式(15):结构型模式专题总结(转)

    摘要:结构型模式,顾名思义讨论的是类和对象的结构,它采用继承机制来组合接口或实现(类结构型模式),或者通过组合一些对象,从而实现新的功能(对象结构型模式).这些结构型模式,它们在某些方面具有很大的相似 ...

  2. JS This关键字

    http://www.ruanyifeng.com/blog/2010/04/using_this_keyword_in_javascript.html http://www.cnblogs.com/ ...

  3. POJ 2480 Longge's problem (积性函数,欧拉函数)

    题意:求∑gcd(i,n),1<=i<=n思路:f(n)=∑gcd(i,n),1<=i<=n可以知道,其实f(n)=sum(p*φ(n/p)),其中p是n的因子.为什么呢?原因 ...

  4. js-jQuery对象与dom对象相互转换

    http://blog.csdn.net/jueshengtianya/article/details/8823091   核心提示:jquery选择器得到的jquery对象和标准的 javascri ...

  5. Android开发者应该深入学习的10个开源应用项目

    Android 开发带来新一轮热潮让很多移动开发者都投入到这个浪潮中去了,创造了许许多多相当优秀的应用.其中也有许许多多的开发者提供了应用开源项目,贡献出他们的 智慧和创造力.学习开源代码是掌握技术的 ...

  6. ExtJs之Ext.core.DomHelper.append

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

  7. 错误处理--pure specifier can only be specified for functions

    错误处理--pure specifier can only be specified for functions 今天下载了log4cpp的源代码,在VC6下编译时出现错误: ..\..\includ ...

  8. maven本地仓库.m2文件夹路径讲解

    Maven是一个项目管理工具,它包含了一个项目对象模型 (Project Object Model),一组标准集合,一个项目生命周期(Project Lifecycle),一个依赖管理系统(Depen ...

  9. http://www.cnblogs.com/flyoung2008/archive/2013/08/11/3251148.html

    http://www.cnblogs.com/flyoung2008/archive/2013/08/11/3251148.html

  10. IE9 JSON未定义

    原文:http://social.msdn.microsoft.com/Forums/ie/en-US/fc41127c-0243-4d2e-8e7c-2b311f12e390/ie9-json-no ...