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.创建带参数的存储过程 简单来说,存储过程就是一条或 ...
随机推荐
- S3C6410板子移植 Android2.2
一:Android简介 1.什么是Android: Android是一种基于linux的自由及开放源代码的操作系统,主要适用于移动设备,如智能手机和平板电脑,是由google公司和开放手机联盟领导和开 ...
- Switch在swift中的使用
switch的简单使用: 相比 C 和 objective - C 中的 switch 语句,Swift 中的 switch 语句不会默认的掉落到每个 case 的下面进入 另一个 case.相反,第 ...
- 【手记】解决启动SQL Server Management Studio 17时报Cannot find one of more components...的问题
刚装好SSMS 17.1准备体验,弹出: 一番搜索,普遍办法都是安装VS2015独立shell.删除某个注册表项什么的,没用,首先这个shell我是装了的,然后也没有那个注册表项.我自己尝试过重装sh ...
- VirtualBox报错:不能为虚拟电脑XXX打开一个新任务
报错产生的背景 今天在这里下载了一个用于VirtualBox的Kali Linux虚拟机文件(使用VirtualBox可以直接打开使用,不用执行安装过程).但是将该文件导入到VirtualBox中之后 ...
- 微信H5中静默登录及非静默登录的正确使用姿势
在微信中打开网页且需要调用微信登录接口时,微信官方给我们提供了两种登录调用方式:静默登录和非静默登录:但是官方文档中却没有说明在何种情况下使用静默登录,何种情况下使用非静默登录,所以在这里,我想将之前 ...
- 关于Kafka __consumer_offests的讨论
众所周知,__consumer__offsets是一个内部topic,对用户而言是透明的,除了它的数据文件以及偶尔在日志中出现这两点之外,用户一般是感觉不到这个topic的.不过我们的确知道它保存的是 ...
- diskqueue.go
}
- redis结合自定义注解实现基于方法的注解缓存,及托底缓存的实现
本次分享如何使用redis结合自定义注解实现基于方法的注解缓存,及托底缓存的实现思路 现在的互联网公司大多数都是以Redis作为缓存,使用缓存的优点就不赘述了,写这篇文章的目的就是想帮助同学们如 ...
- Bootstrap 小结
Bootstrap 小结 Bootstrap4特点:1.兼容IE10+ 2.使用flexbox 布局 3.抛弃Nomalize.css 4.提供布局和 reboot 版本 Bootstrap组成:1. ...
- 「WC 2018」州区划分
题目大意: 给一个无向图$G(V,E)$满足$|V|<=21$,对于某一种将$G(V,E)$划分为k个的有序集合方案,若每一个子集$G_i(V_i,E_i)$,$E_i=\{(x,y)|x\in ...