oracle将一个时间段分割,Oracle根据时间将一条记录进行分割成多条(开始时间与结束时间跨几天就分割成几条)...

首先对需求进行一下说明:

假如我们A表里面有一条记录是这样的:

0818b9ca8b590ca3270a3433284dd417.png

三个字段,第一个为MDN(号码),第二个为STARTTIME(开始时间),第三个为ENDTIME(结束时间)

现需要对表中所有这种开始时间与结束时间不在同一天的记录进行拆分,时间跨度几天就拆分成几条:

0818b9ca8b590ca3270a3433284dd417.png

以上为实现后的效果图,由于之前对Oracle的游标不太了解,请教了组长,后来也仔细看了下

游标的使用,这个实现也并不难。主要是首先计算两个时间的跨度为几天,然后通过循环,将对应

的记录插入到另一张表中去。其中tableA是原始表,tableB是新表,v_d表示时间跨度的变量,其他变量

对应表字段。

declare

-- Local variables here

v_startTime date;

v_endTime date;

v_mdn int;

v2_startTime date;

v2_endTime date;

v_d int;

cursor cr is

select mdn,startTime,endTime from tableA

where trunc(endTime,'dd') - trunc(startTime,'dd') > 0;

begin

-- Test statements here

open cr;

LOOP

fetch cr into v_mdn,v_startTime,v_endTime;

exit when cr%notfound;

v_d :=trunc(v_endTime,'dd') - trunc(v_startTime,'dd') -1;

dbms_output.put_line(v_d);

insert into tableB values(v_mdn,trunc(v_endTime,'dd'),v_endTime);

loop

exit when v_d=0;

v2_startTime := trunc(v_startTime,'dd') + v_d;

dbms_output.put_line(to_char(v2_startTime,'yyyy-MM-dd'));

v2_endTime := v2_startTime + 1;

insert into tableB values(v_mdn,v2_startTime,v2_endTime);

v_d:=v_d-1;

end loop;

insert into tableB values(v_mdn,v_startTime,trunc(v_startTime,'dd')+1);

end loop;

close cr;

end;

/

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值