开发过程中多个时间段是否有交集 函数+sql(笔记)

create or replace function zx_jx_func_istimecross(dbstartdate   in date,
                                            db_enddate  in date,
                                            startdate IN date,
                                            enddate  IN date) return number is
  result number;
begin
  result := 0;
  if (startdate < dbstartdate) then
    --开始时间 < 已经存在的开始时间
    if (enddate >= db_enddate) then
      --结束时间 >= 已经存在的的结束时间 说明有交集
      result := 1;
    end if;
  end if;
  if (startdate >= dbstartdate) then
    --如果请假开始时间>应上班时间,只要在下班时间之前,则也说明有集
    if (startdate <= db_enddate) then
      result := 1;
    end if;
  end if;
  return(result);
end zx_jx_func_istimecross;

还可以使用sql过滤:思路如下,(aa.startdate between bb.startdate and bb.enddate or
                aa.enddate between bb.startdate and bb.enddate or
                bb.startdate between aa.startdate and aa.enddate or
                bb.enddate between aa.startdate and aa.enddate)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值