概述
这部分内容是要在数据已备份或者迁移成功的基础上才做的,前面我们已经针对这表空间千万级别以上的表做了迁移,并数据校验一致了,下面主要是来删除源库上的数据了。
1、删除源库数据
1.1、存储过程删除
因为有一张上亿的表,如果直接删除怕UNDO空间爆了,所以写了个存储过程来循环删除,内容如下:
create table t_jindu(id int,name varchar2(60),sum int);declare i int; --定义变量v_count int; --定义变量v_loop int; --定义变量begin select count(*) into v_count from TAB_SP_OTMSHIPMENT where insert_time<=to_date('20180630 00:00:00','yyyymmdd hh24:mi:ss') ; --计算表 select ceil(v_count/5000) into v_loop from dual; --计算需要循环次数 i:=1; --为i赋值 while i<=v_loop loop --循环退出条件 delete from TAB_SP_OTMSHIPMENT where insert_time<=to_date('20180630 00:00:00','yyyymmdd hh24:mi:ss') and rownum<5000; insert into t_jindu values(i,'TAB_SP_OTMSHIPMENT',v_loop); --记录删除次数进度 commit; --提交 i:=i+1; --i依次加1 end loop;EXCEPTION WHEN OTHERS THEN R