oracle 大于当天时间_oracle 计算时间差,排除非工作时间

这篇博客讨论了如何使用Oracle SQL编写函数来计算两个时间点之间的工作时间差,尤其关注8-12点和14-18点的工作时间,并排除非工作时间。博主发现现有算法在某些临界情况下有误,并分享了修正后的代码示例。
摘要由CSDN通过智能技术生成

要求只计算 8-12,14-18,我现在 csdn 找见有人探讨写的算法,结果仔细一侧,有些临界的地方就算不对了,比如 17:50 到第二天 8:10,算出来不是 20 分钟,好复杂啊,就只用 oracle 的话到底怎么能写对?

create or replace function wk_minutes_between(

i_startTime varchar2, -- 起始时间:( 格式:'YYYY-MM-DD HH24:MI:SS' )

i_endTime varchar2 -- 结束时间:( 格式:'YYYY-MM-DD HH24:MI:SS' )

)

return number

is

v_real_startTime date;

v_real_endTime date;

v_hours number(18,0);

v_number number(18,4);

begin

v_real_startTime := to_date(i_startTime,'YYYY-MM-DD HH24:MI:SS');

v_real_endTime := to_date(i_endTime,'YYYY-MM-DD HH24:MI:SS');

if v_real_startTime > v_real_endTime -- 如果起始时间大于结束时间,将起始时间与结束时间替换

then

select v_real_startTime, v_real_endTime into v_real_endTime, v_real_startTime f

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值