postgresql 实现计算日期间隔排除周末节假日方案

本文主要是介绍postgresql 实现计算日期间隔排除周末节假日方案,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前置条件:需要维护一张节假日日期表。例如创建holiday表保存当年假期日期

CREATE TABLE `holiday` (`id` BIGINT(10) ZEROFILL NOT NULL DEFAULT 0,`day` TIMESTAMP NULL DEFAULT NULL,PRIMARY KEY (`id`)
)
COMMENT='假期表'
COLLATE='utf8mb4_0900_ai_ci'
;

返回日期为xx日xx时xx分格式,可以在此基础上调整格式

-- FUNCTION: public.get_timedelay(timestamp with time zone, timestamp with time zone)-- DROP FUNCTION IF EXISTS public.get_timedelay(timestamp with time zone, timestamp with time zone);CREATE OR REPLACE FUNCTION public.get_timedelay(starttime timestamp with time zone,endtime timestamp with time zone)RETURNS textLANGUAGE 'plpgsql'COST 100VOLATILE PARALLEL UNSAFE
AS $BODY$
DECLAREv_return  varchar;--返回间隔时间 xx日xx时xx分v_minute  integer;--间隔分钟v_hour integer;v_temp_minute integer;v_temp_hour integer;v_day integer; --间隔天数v_all numeric;v_counter integer;v_end_weekend integer;v_weekend integer;--周一_周日 1_6_0v_holiday numeric;--匹配节假日天数v_is_weekend boolean; --是否周末v_is_holiday boolean; --是否节假日
BEGIN--计算时间间隔天数select ceil(DATE_PART('epoch', endtime::timestamp - starttime::TIMESTAMP)/60/60/24) into v_all;--减去周末、节假日v_end_weekend := cast(EXTRACT(DOW FROM (endtime)) as int);v_day := 0;v_hour := 0;v_minute := 0;v_counter := 0;while v_counter <= v_all loopv_temp_minute := 0;v_temp_hour  := 0;v_is_weekend := FALSE;v_is_holiday := FALSE;--判断该日期为周几v_weekend := v_end_weekend-v_counter%7;if v_weekend < 0 thenv_weekend := v_weekend + 7;end if;if v_weekend = 6 or v_weekend = 0 thenv_is_weekend := true;end if;--判断该日期是否为节假日--日期表SELECT COUNT(*) FROM holiday WHERE Date(endtime) - DATE(day) - v_counter  = 0 INTO v_holiday;if v_is_weekend = false and v_holiday > 0 thenv_is_holiday := true;end if;--累计时长if v_is_weekend = false AND v_is_holiday = false thenif v_counter = 0  thenv_minute := cast(date_part('minute', endtime::TIMESTAMP) as int);v_hour := cast(date_part('hour', endtime::TIMESTAMP) as int);elseif v_counter = v_all thenv_temp_minute := 60 - cast(date_part('minute', endtime::TIMESTAMP) as int);v_temp_hour := 23 - cast(date_part('hour', endtime::TIMESTAMP) as int);v_minute := (v_minute+v_temp_minute) % 60;v_temp_hour := v_temp_hour+FLOOR((v_minute+v_temp_minute)/60);v_hour := (v_hour+v_temp_hour) % 24;v_day := v_day + FLOOR((v_hour+v_temp_hour) / 24);elsev_day := v_day + 1;end if;end if;v_counter:= v_counter+1;end loop;--处理返回日期v_return := '';--返回日、时、分方案if v_day > 0 thenv_return := concat(v_return, v_day,'日');end if;if v_hour > 0 thenv_return := concat(v_return, v_hour,'时');end if;if v_minute > 0 thenv_return := concat(v_return,v_minute,'分');end if;RETURN v_return;EXCEPTION WHEN OTHERS THENRETURN SQLERRM;END;
$BODY$;ALTER FUNCTION public.get_timedelay(timestamp with time zone, timestamp with time zone)OWNER TO postgres;

这篇关于postgresql 实现计算日期间隔排除周末节假日方案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/383627

相关文章

Flutter实现文字镂空效果的详细步骤

《Flutter实现文字镂空效果的详细步骤》:本文主要介绍如何使用Flutter实现文字镂空效果,包括创建基础应用结构、实现自定义绘制器、构建UI界面以及实现颜色选择按钮等步骤,并详细解析了混合模... 目录引言实现原理开始实现步骤1:创建基础应用结构步骤2:创建主屏幕步骤3:实现自定义绘制器步骤4:构建U

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

Android实现定时任务的几种方式汇总(附源码)

《Android实现定时任务的几种方式汇总(附源码)》在Android应用中,定时任务(ScheduledTask)的需求几乎无处不在:从定时刷新数据、定时备份、定时推送通知,到夜间静默下载、循环执行... 目录一、项目介绍1. 背景与意义二、相关基础知识与系统约束三、方案一:Handler.postDel

windows和Linux使用命令行计算文件的MD5值

《windows和Linux使用命令行计算文件的MD5值》在Windows和Linux系统中,您可以使用命令行(终端或命令提示符)来计算文件的MD5值,文章介绍了在Windows和Linux/macO... 目录在Windows上:在linux或MACOS上:总结在Windows上:可以使用certuti

电脑找不到mfc90u.dll文件怎么办? 系统报错mfc90u.dll丢失修复的5种方案

《电脑找不到mfc90u.dll文件怎么办?系统报错mfc90u.dll丢失修复的5种方案》在我们日常使用电脑的过程中,可能会遇到一些软件或系统错误,其中之一就是mfc90u.dll丢失,那么,mf... 在大部分情况下出现我们运行或安装软件,游戏出现提示丢失某些DLL文件或OCX文件的原因可能是原始安装包

电脑显示mfc100u.dll丢失怎么办?系统报错mfc90u.dll丢失5种修复方案

《电脑显示mfc100u.dll丢失怎么办?系统报错mfc90u.dll丢失5种修复方案》最近有不少兄弟反映,电脑突然弹出“mfc100u.dll已加载,但找不到入口点”的错误提示,导致一些程序无法正... 在计算机使用过程中,我们经常会遇到一些错误提示,其中最常见的就是“找不到指定的模块”或“缺少某个DL

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B