SQL Server函数与存储过程 计算时间
一、通过一个开始时间、结束时间计算出一个工作日天数(不包含工作日与节假日),节假日在 holidays 表中维护;
1、函数
--创建函数,参数 @bengrq 开始时间,@endrq 结束时间
create function [dbo].[f_jsgzr](@bengrq date,@endrq date)
--返回值类型 天数
returns int
begin
--计算出开始时间与结束时间的相差的天数,通过这个天数减去查询出来的节假日与休息日天数
--@jats 节假日,@gzrts 总天数,@gzrts 返回值 工作日天数
declare @jats int,@zts int,@gzrts int
--数据库中存在一张记录节假日与休息日的表,通过这张表合计两个时间段中包含的节假日天数
select @jats = count(1)
from holidays rq where rq.hldys >= @bengrq and rq.hldys <= @endrq
select @zts = DATEDIFF(day,@bengrq,@endrq)
--计算工作日 = 总天数 - 假节日天数
select @gzrts = @zts - @jats
--返回工作日天数
return @gzrts
end --执行函数,输入参数
SELECT [dbo].[f_jjr] ('2019-02-11','2019-02-18')
GO
2、存储过程
/*创建存储过程 计算工作日*/create procedure jjr
--参数 @bengrq 开始时间,@endrq 结束时间、@gzrts 工作日天数
@bengrq date,@endrq date,@gzrts int output as
begin
--计算出开始时间与结束时间的相差的天数,通过这个天数减去查询出来的节假日与休息日天数
declare @jats int,@zts int
--数据库中存在一张记录节假日与休息日的表,通过这张表合计两个时间段中包含的节假日天数
select @jats = count(1)
from holidays rq where rq.hldys >= @bengrq and rq.hldys <= @endrq
select @zts = DATEDIFF(day,@bengrq,@endrq)
--计算工作日 = 总天数 - 假节日天数
select @gzrts = @zts - @jats
print @gzrts
--返回天数
return @gzrts
end --声明变量
declare @bengrq date,@endrq date,@gzrts int
--给变量赋值
select @bengrq = '2019-02-01',@endrq = '2019-03-01'
--调用存储过程
EXEC jjr @bengrq,@endrq,@gzrts output
二、通过一个开始时间、天数计算出一个结束时间(不包含工作日与节假日);
使用循环来实现;
/*创建函数通过工作日天数,获取结束时间*/
--@bengrq 开始时间,@gzrts 工作日天数
create function dbo.f_jsjsrq(@bengrq date,@gzrts int)
--返回值类型 结束时间
returns date
begin
--@jats 节假日,@addDate 返回值 结束日
declare @jats int,@endrq date
--为 @endrq 结束时间赋值,从 @bengrq 开始时间的第二天开始
select @endrq = @bengrq --工作日天数大于0时循环查询节假日表数据
while @gzrts >= 0
begin
--每次查询时 @jats 节假日等于0
select @jats = 0
select @jats = count(1) from holidays rq where rq.hldys = @endrq
if @jats > 0
begin
select @endrq = dateadd(day,1,@endrq)
end else begin
--@endrq 当前日期不是节假日时工作日天数减1
select @gzrts = @gzrts - 1
--当工作日天数小于0时跳出循环
if @gzrts < 0
begin
break;
end
select @endrq = dateadd(day,1,@endrq)
end
end
--返回日期
return @endrq
end --执行函数,参数 开始时间、工作日天数
SELECT dbo.f_jsjsrq ('2019-02-01',16)
SQL Server函数与存储过程 计算时间的更多相关文章
- Sql Server函数全解<四>日期和时间函数
原文:Sql Server函数全解<四>日期和时间函数 日期和时间函数主要用来处理日期和时间值,本篇主要介绍各种日期和时间函数的功能和用法,一般的日期函数除了使用date类型的参数外, ...
- SQL SERVER 函数大全[转]
SQL Server 函数大全 一旦成功地从表中检索出数据,就需要进一步操纵这些数据,以获得有用或有意义的结果.这些要求包括:执行计算与数学运算.转换数据.解析数值.组合值和聚合一个范围内的值等. 下 ...
- 理解性能的奥秘——应用程序中慢,SSMS中快(2)——SQL Server如何编译存储过程
本文属于<理解性能的奥秘--应用程序中慢,SSMS中快>系列 接上文:理解性能的奥秘--应用程序中慢,SSMS中快(1)--简介 本文介绍SQL Server如何编译存储过程并使用计划缓存 ...
- 【转载】SQL SERVER 函数大全
SQL Server 函数大全 一旦成功地从表中检索出数据,就需要进一步操纵这些数据,以获得有用或有意义的结果.这些要求包括:执行计算与数学运算.转换数据.解析数值.组合值和聚合一个范围内的值等. 下 ...
- sql server 函数的自定义
创建用户定义函数.这是一个已保存 Transact-SQL 或公共语言运行时 (CLR) 例程,该例程可返回一个值.用户定义函数不能用于执行修改数据库状态的操作.与系统函数一样,用户定义函数可从查询中 ...
- SQL Server基础之存储过程
简单来说,存储过程就是一条或者多条sql语句的集合,可视为批处理文件,但是其作用不仅限于批处理.本篇主要介绍变量的使用,存储过程和存储函数的创建,调用,查看,修改以及删除操作. 一:存储过程概述 ...
- 【SQL Server】SQL Server基础之存储过程
SQL Server基础之存储过程 阅读目录 一:存储过程概述 二:存储过程分类 三:创建存储过程 1.创建无参存储过程 2.修改存储过程 3.删除存储过程 4.重命名存储过程 5.创建带参数的存储 ...
- (转)SQL Server基础之存储过程(清晰使用)
阅读目录 一:存储过程概述 二:存储过程分类 三:创建存储过程 1.创建无参存储过程 2.修改存储过程 3.删除存储过程 4.重命名存储过程 5.创建带参数的存储过程 简单来说,存储过程就是一条或 ...
- Sql Server数据库之存储过程
阅读目录 一:存储过程概述 二:存储过程分类 三:创建存储过程 1.创建无参存储过程 2.修改存储过程 3.删除存储过程 4.重命名存储过程 5.创建带参数的存储过程 简单来说,存储过程就是一条或 ...
随机推荐
- 使用Eclipse打开已有工程
点击Eclipse界面中的file(文件)下的import(导入). 进入导入界面,选择General下的Exiting Project into Workspace. 点击Select ...
- Zookeeper vs etcd vs Consul
Zookeeper vs etcd vs Consul [编者的话]本文对比了Zookeeper.etcd和Consul三种服务发现工具,探讨了最佳的服务发现解决方案,仅供参考. 如果使用预定义的端口 ...
- 【手记】解决启动SQL Server Management Studio 17时报Cannot find one of more components...的问题
刚装好SSMS 17.1准备体验,弹出: 一番搜索,普遍办法都是安装VS2015独立shell.删除某个注册表项什么的,没用,首先这个shell我是装了的,然后也没有那个注册表项.我自己尝试过重装sh ...
- Java基础之抽象类
/* 1.抽象类的概述: 动物不应该定义为具体的东西,而且动物中的吃,睡等也不应该是具体的. 我们把一个不是具体的功能称为抽象的功能,而一个类中如果有抽象的功能,该类必须是抽象类. 抽象类的特点: A ...
- windows7 dos修改mysql root密码
第一步:打开mysql 安装路径 选择bin文件 同时按下Shift+鼠标右键 点击"在此处打开命令" 第二步:输入mysql -u root -p 按回车键会提示输入密码 ...
- Python字符串的操作
字符串常用操作 name = "my name is alex" # 注: python中方法名前后带下划线的是供内部使用的方法, 如方法__dir__(). 这种方法是不对外提供 ...
- Go性能优化小结
1 内存优化 1.1 小对象合并成结构体一次分配,减少内存分配次数 做过C/C++的同学可能知道,小对象在堆上频繁地申请释放,会造成内存碎片(有的叫空洞),导致分配大的对象时无法申请到连续的内存空间, ...
- 关于CocoaPods的ruby镜像文件问题
项目遇到第三方库更新问题 时 用到cocoaPods更换淘宝ruby镜像问题的时候 报错 后来 又在别处找了下 发现 用的是 https 如下: 后来细想 可能跟Xcode7 要求HTTPs ...
- 学习React Native必看的几个开源项目
学习React native ,分享几个不错的开源项目,相信你学完之后,一定会有所收获.如果还没有了解RN的同学们可以参考手把手教你React Native 实战之开山篇<一> 1.Fac ...
- matplotlib解决中文乱码
调试以前写的matplotlib相关脚本,中文呈方块样:重新解决一遍,感觉比以前的理解更进一步,故而记下一笔: 1. 首先要为matplotlib添加中文字体库: 系统字体库在/usr/share/f ...