delete 分批提交删除数据表记录

来源:互联网 发布:全日制本科助学班 知乎 编辑:程序博客网 时间:2024/06/05 07:42

由于业务需要,需要对业务表数据进行删除,所以借鉴eygle的方式,如下:

create or replace procedure del_datpayment  
(
p_TableName in varchar2,--表名
p_Condition in varchar2,--条件
p_Count in varchar2--每批提交的条数
)
as
pragma autonomous_transaction;
n_delete number:=0;
begin
while 1=1 loop
EXECUTE IMMEDIATE
'delete from '||p_TableName||' where '||p_Condition||' and rownum <= :rn'
USING p_Count;
if SQL%NOTFOUND then
exit;
else
n_delete:=n_delete + SQL%ROWCOUNT;
end if;
commit;
end loop;
commit;
DBMS_OUTPUT.PUT_LINE('Finished!');
DBMS_OUTPUT.PUT_LINE('Totally '||to_char(n_delete)||' records deleted!');
end;

 

原创粉丝点击