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

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

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

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

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

以上为实现后的效果图,由于之前对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;
/


 

猜你喜欢

转载自blog.csdn.net/smach1991710/article/details/13002891