问题:
计算表格3中每条记录从保存日期到当前时间已经过了多少工作小时,即是不包括星期六日和节假日,并且节假日是根据不同国家来定的。计算出来的结果要保存到‘保存期’当中。由于考虑到我们国家经常会调整放假,所以我创建了两个保存假期的表格。一个用来保存发生在工作日的假期;另一个是用来保存是星期六日但由于假日调整,我们必须上班的日子。这两个表格结构类似。如下
表格1 表格2
假期 国家 周末但是工作日 国家
表格3文件名 保存日期 国家 保存期
计算表格3中每条记录从保存日期到当前时间已经过了多少工作小时,即是不包括星期六日和节假日,并且节假日是根据不同国家来定的。计算出来的结果要保存到‘保存期’当中。由于考虑到我们国家经常会调整放假,所以我创建了两个保存假期的表格。一个用来保存发生在工作日的假期;另一个是用来保存是星期六日但由于假日调整,我们必须上班的日子。这两个表格结构类似。如下
表格1 表格2
假期 国家 周末但是工作日 国家
表格3文件名 保存日期 国家 保存期
解决方案 »
- 求助:如果unique键有记录则更新记录,如果没有则插入。某个值为1更新字段1,该值为2则更新字段2.....依次类推。求sql语句该如何写
- 像省市级联那样的SQL查询问题
- 我有一个表要保存email的地址,可输入"@"就报错,去掉就可以,怎么办啊
- 如何设置主键
- 初来乍到,请假高手们几个小问题
- 高手请进:-------这样的SQL追加语句怎么写?----------高分求解
- 请教SQL语句,将子表的多条记录中的内容合并在一条记录
- 求一个考勤系统,计算有效工作时间的SQL
- 请问“当前数据库中已存在用户或角色”的问题
- SQL触发器对象不存在问题求解决
- mysql字符集问题 MD5
- 没有任何数据库的菜鸟想学SQL有谱吗?
drop table [tb_Holiday]
GO--定义节假日表
CREATE TABLE tb_Holiday(
HDate smalldatetime primary key clustered, --节假日期
Name nvarchar(50) not null) --假日名称
GOif 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
GOif 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[/code]