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

简介: 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

相关文章
|
6月前
|
SQL 人工智能 数据挖掘
如何在`score`表中正确使用`COUNT`和`AVG`函数?SQL聚合函数COUNT与AVG使用指南
本文三桥君通过score表实例解析SQL聚合函数COUNT和AVG的常见用法。详解COUNT(studentNo)、COUNT(score)、COUNT()的区别,以及AVG函数对数值/字符型字段的不同处理,特别指出AVG()是无效语法。实战部分提供6个典型查询案例及结果,包含创建表、插入数据的完整SQL代码。产品专家三桥君强调正确理解函数特性(如空值处理、字段类型限制)对数据分析的重要性,帮助开发者避免常见误区,提升查询效率。
380 0
|
存储 SQL 数据库
SQL Server存储过程的优缺点
【10月更文挑战第18天】SQL Server 存储过程具有提高性能、增强安全性、代码复用和易于维护等优点。它可以减少编译时间和网络传输开销,通过权限控制和参数验证提升安全性,支持代码共享和复用,并且便于维护和版本管理。然而,存储过程也存在可移植性差、开发和调试复杂、版本管理问题、性能调优困难和依赖数据库服务器等缺点。使用时需根据具体需求权衡利弊。
363 1
|
9月前
|
SQL 存储 大数据
Dataphin V5.0:支持创建异步调用API,实现慢 SQL 复杂计算的直连消费
本文介绍了数据服务产品中异步调用的应用场景与优势,包括大数据引擎查询、复杂SQL及大规模数据下载等场景,解决了同步调用可能导致的资源浪费和性能问题。通过创建异步API、测试发布以及权限申请等功能,实现高效稳定的服务提供。以电商订单查询为例,展示了如何利用异步调用提升系统性能与用户体验。
383 9
|
9月前
|
存储 SQL 数据库连接
C#程序调用Sql Server存储过程异常处理:调用存储过程后不返回、不抛异常的解决方案
本文分析了C#程序操作Sql Server数据库时偶发的不返回、不抛异常问题,并提出了解决思路。首先解析了一个执行存储过程的函数`ExecuteProcedure`,其功能是调用存储过程并返回影响行数。针对代码执行被阻塞但无异常的情况,文章总结了可能原因,如死锁、无限循环或网络问题等。随后提供了多种解决方案:1) 增加日志定位问题;2) 使用异步操作提升响应性;3) 设置超时机制避免阻塞;4) 利用线程池分离主线程;5) 通过信号量同步线程;6) 监控数据库连接状态确保可用性。这些方法可有效应对数据库操作中的潜在问题,保障程序稳定性。
712 11
|
SQL Oracle 关系型数据库
SQL优化-使用联合索引和函数索引
在一次例行巡检中,发现一条使用 `to_char` 函数将日期转换为字符串的 SQL 语句 CPU 利用率很高。为了优化该语句,首先分析了 where 条件中各列的选择性,并创建了不同类型的索引,包括普通索引、函数索引和虚拟列索引。通过对比不同索引的执行计划,最终确定了使用复合索引(包含函数表达式)能够显著降低查询成本,提高执行效率。
270 3
|
存储 SQL 缓存
SQL Server存储过程的优缺点
【10月更文挑战第22天】存储过程具有代码复用性高、性能优化、增强数据安全性、提高可维护性和减少网络流量等优点,但也存在调试困难、移植性差、增加数据库服务器负载和版本控制复杂等缺点。
580 1
|
存储 SQL 数据库
SQL Server存储过程的优缺点
【10月更文挑战第17天】SQL Server 存储过程是预编译的 SQL 语句集,存于数据库中,可重复调用。它能提高性能、增强安全性和可维护性,但也有可移植性差、开发调试复杂及可能影响数据库性能等缺点。使用时需权衡利弊。
310 3
|
存储 SQL 数据库
Sql Server 存储过程怎么找 存储过程内容
Sql Server 存储过程怎么找 存储过程内容
770 1
|
存储 Java 关系型数据库
java调用mysql存储过程
在 Java 中调用 MySQL 存储过程主要借助 JDBC(Java Database Connectivity)。其核心原理是通过 JDBC 与 MySQL 建立连接,调用存储过程并处理结果。具体步骤包括:加载 JDBC 驱动、建立数据库连接、创建 CallableStatement 对象、设置存储过程参数并执行调用。此过程实现了 Java 程序与 MySQL 数据库的高效交互。
|
11月前
|
存储 关系型数据库 MySQL
【YashanDB知识库】MySQL返回结果集的存储过程的改写方法
本文介绍了将MySQL存储过程改写至YashanDB的解决方案。由于MySQL存储过程可直接返回结果集,而YashanDB需通过返回SYS_REF_CURSOR的函数实现类似功能,因此需要对代码进行转换。示例中展示了如何将MySQL存储过程`proc1`改写为YashanDB函数,并调整JDBC应用代码以适配REF_CURSOR输出参数,从而正确获取查询结果。此方法确保了跨数据库场景下的兼容性与功能性。