create or replace procedure DeleteBigTable
(
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;
批量删除的一个脚本
最新推荐文章于 2021-04-03 16:18:42 发布
本文介绍了一种在Oracle数据库中批量删除大表数据的方法。通过创建存储过程,使用循环和动态SQL执行删除操作,并利用自主事务确保每轮删除指定数量的记录后自动提交,以避免长时间锁定整个表。
1272

被折叠的 条评论
为什么被折叠?



