oracle FUNCTION(任意两个时间 之间的工作小时)

news/2024/6/18 23:47:29 标签: oracle, 数据库

写函数计算 任意两个时间 之间的工作小时
每天工作时间(8:00 - 20:00 共12小时),没有休息日

 CREATE OR REPLACE FUNCTION SC_YD_DESI.CALCULATE_WORK_HOURS_FUNC (
    p_current_time IN DATE,
    p_order_time IN DATE
) RETURN NUMBER
AS
    p_work_hours NUMBER := 0;
    p_work_time DATE := p_order_time;
    v_hours NUMBER := 0;
BEGIN
    -- 计算第一天的工作时间
    IF TRUNC(p_current_time) >= TRUNC(p_work_time) THEN
        IF TO_NUMBER(TO_CHAR(p_current_time, 'HH24')) >= 8 AND TO_NUMBER(TO_CHAR(p_current_time, 'HH24')) < 20 THEN
            v_hours := (p_current_time - p_work_time) * 24 ;
        ELSIF TO_NUMBER(TO_CHAR(p_current_time, 'HH24')) >= 20 THEN
            v_hours := 20 - (TO_NUMBER(TO_CHAR(p_work_time, 'HH24')) + TO_NUMBER(TO_CHAR(p_work_time, 'MI')/60)); -- 20:00到次日08:00共计12小时
        END IF;
        p_work_hours := p_work_hours + v_hours ;
        p_work_time := p_work_time + 1;
    END IF;

    -- 计算中间整天的工作时间
    WHILE TRUNC(p_work_time) < TRUNC(p_current_time) LOOP
        p_work_hours := p_work_hours + 12;
        p_work_time := p_work_time + 1;
    END LOOP;

    -- 计算最后一天的工作时间
    IF TRUNC(p_work_time) = TRUNC(p_current_time) THEN
        IF TO_NUMBER(TO_CHAR(p_current_time, 'HH24')) >= 8 AND TO_NUMBER(TO_CHAR(p_current_time, 'HH24')) < 20 THEN
            v_hours := (p_current_time - (TRUNC(SYSDATE) + INTERVAL '8' HOUR)) * 24 ;
        ELSIF TO_NUMBER(TO_CHAR(p_current_time, 'HH24')) >= 20 THEN
            v_hours := 12; 
        END IF;
        p_work_hours := p_work_hours + v_hours ;
        p_work_time := p_work_time + 1;
    END IF;

    RETURN p_work_hours;
END CALCULATE_WORK_HOURS_FUNC;

调用函数结果:

SELECT SC_YD_DESI.CALCULATE_WORK_HOURS_FUNC(
    TO_DATE('2022-11-10 23:00:00', 'YYYY-MM-DD HH24:MI:SS'),
    TO_DATE('2022-11-07 10:50:00', 'YYYY-MM-DD HH24:MI:SS')
) AS work_hours
FROM DUAL;

在这里插入图片描述


http://www.niftyadmin.cn/n/5221546.html

相关文章

C语言第三十四弹--矩形逆置

C语言实现矩阵逆置 逆置结果如图 思路&#xff1a;通过观察逆置结果&#xff0c;首先发现行数和列数都发生了调换。其次观察逆置前后数字对应的下标&#xff0c;逆置前数字对应下标为:[x][j] 逆置后数字对应下标为&#xff1a;[y][x]。综上&#xff0c;就可以实现矩阵逆置。 …

【面经八股】搜广推方向:常见面试题(六)

【面经&八股】搜广推方向:常见面试题(六) 文章目录 【面经&八股】搜广推方向:常见面试题(六)1. Memorization 和 Generalization2. Wide 和 Deep3. Cross-product transformation4. 推荐系统划分5. 线性模型6. Embedding-Based 模型7. 推荐系统工作流程8. Wide P…

【python】——组合数据类型(单选练习题)

&#x1f383;个人专栏&#xff1a; &#x1f42c; 算法设计与分析&#xff1a;算法设计与分析_IT闫的博客-CSDN博客 &#x1f433;Java基础&#xff1a;Java基础_IT闫的博客-CSDN博客 &#x1f40b;c语言&#xff1a;c语言_IT闫的博客-CSDN博客 &#x1f41f;MySQL&#xff1a…

Android Handler同步屏障:深入解析

Android Handler同步屏障&#xff1a;深入解析 在Android开发中&#xff0c;Handler和MessageQueue是处理线程间通信的重要组件。除了常见的消息发送和处理功能&#xff0c;Handler还提供了一个高级特性&#xff1a;同步屏障。本文将深入探讨这一特性&#xff0c;包括它的工作…

#Js篇:前端的设计模式有哪些

常见的前端设计模式 单例模式 保证一个类仅有一个实例&#xff0c;并提供一个访问他的全局访问点&#xff1b;vuex常用于管理全局状态、配置信息等。 工厂模式 一个用于创建对象的接口&#xff0c;让子类决定实例化哪个类&#xff1b; 创建复杂对象或对象的组合。 策略模…

大模型fine-tune 微调

大模型的 Fine-tune 我们对技术的理解&#xff0c;要比技术本身更加重要。 正如我在《大模型时代的应用创新范式》一文中所说&#xff0c;大模型会成为AI时代的一项基础设施。 作为像水、电一样的基础设施&#xff0c;预训练大模型这样的艰巨任务&#xff0c;只会有少数技术…

京东平台双11全品类完整销售数据回顾(京东大数据-京东数据采集-京东数据接口)

今年的双十一&#xff0c;大家依然没有等到各大平台的官方战报。 所以&#xff0c;对于绝大部分品牌、商家、咨询公司乃至有数据研究需求的小伙伴来说&#xff0c;很难了解到今年大促消费者的真实消费水平。 为此&#xff0c;鲸参谋简单整理出了10个京东大类目&#xff08;含5…

高级/进阶”算法和数据结构书籍推荐

“高级/进阶”算法和数据结构书籍推荐《高级算法和数据结构》 高级算法和数据结构 为什么要选择本书 谈及为什么需要花时间学算法&#xff0c;我至少可以列举出三个很好的理由。 (1)性能&#xff1a;选择正确的算法可以显著提升应用程序的速度。仅就搜索来说&#xff0c;用二…