SQL Server函数与存储过程 计算时间

本文涉及的产品
云数据库 RDS SQL Server,独享型 2核4GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
简介: SQL Server函数与存储过程 计算时间 一、通过一个开始时间、结束时间计算出一个工作日天数(不包含工作日与节假日);   1、函数 --创建函数,参数 @bengrq 开始时间,@endrq 结束时间 create function [dbo].

SQL Server函数与存储过程 计算时间

一、通过一个开始时间、结束时间计算出一个工作日天数(不包含工作日与节假日);

  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)
复制代码

 原文地址https://www.cnblogs.com/RainHouse/p/10509796.html

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
相关文章
|
12天前
|
SQL XML 关系型数据库
【less-5】基于SQLI的SQL盲注常用函数
【less-5】基于SQLI的SQL盲注常用函数
22 2
|
5天前
|
SQL 数据库
SQL SUM() 函数
SQL SUM() 函数
9 0
|
4天前
|
SQL 数据库
SQL LCASE() 函数
SQL LCASE() 函数
15 7
|
2天前
|
SQL 数据库
SQL FORMAT() 函数
SQL FORMAT() 函数
9 2
|
4天前
|
SQL 数据库
SQL UCASE() 函数
SQL UCASE() 函数
11 4
|
3天前
|
SQL
SQL ROUND() 函数
SQL ROUND() 函数
9 1
|
7天前
|
SQL Oracle 关系型数据库
SQL LAST() 函数
SQL LAST() 函数
14 5
|
8天前
|
SQL Oracle 关系型数据库
SQL FIRST() 函数
SQL FIRST() 函数
12 3
|
8天前
|
SQL Oracle 关系型数据库
SQL COUNT() 函数
SQL COUNT() 函数
12 3
|
6天前
|
SQL 分布式计算 大数据
MaxCompute产品使用问题之odps sql 底层计算框架是MR吗
MaxCompute作为一款全面的大数据处理平台,广泛应用于各类大数据分析、数据挖掘、BI及机器学习场景。掌握其核心功能、熟练操作流程、遵循最佳实践,可以帮助用户高效、安全地管理和利用海量数据。以下是一个关于MaxCompute产品使用的合集,涵盖了其核心功能、应用场景、操作流程以及最佳实践等内容。