Oracle中大批量删除数据的方法

我们还没有老去,却经历了太多风浪,被迫快速的强大,成长起来。心,已然老过了年龄,老过了岁月。
写一个循环删除的过程。
createorreplaceproceduredelBigTab(p_TableNameinvarchar2,p_Conditioninvarchar2,p_Countinvarchar2)
as
pragmaautonomous_transaction;
n_deletenumber:=0;
begin
while1=1loop
EXECUTEIMMEDIATE
'deletefrom'||p_TableName||'where'||p_Condition||'andrownum<=:10000'
USINGp_Count;
ifSQL%NOTFOUNDthen
exit;
else
n_delete:=n_delete+SQL%ROWCOUNT;
endif;
commit;
endloop;
commit;
DBMS_OUTPUT.PUT_LINE('Finished!');
DBMS_OUTPUT.PUT_LINE('Totally'||to_char(n_delete)||'recordsdeleted!');
enddelBigTab;
调用:
SQL>settimingon
SQL>execdelBigTab('HS_DLF_DOWNLOG_HISTORY','NUMDLFLOGGUID<11100000','10000');
PL/SQLproceduresuccessfullycompleted.
Elapsed:00:00:18.54
方法虽好,但我应用在一个亿级数据库时还是觉得慢得不行。就算删一点点数据也觉得好象挺慢的。

本文Oracle中大批量删除数据的方法到此结束。学会示弱,学会赞美别的公司,学会把别的公司给别人共享,不去树敌,那你就优秀了。小编再次感谢大家对我们的支持!

您可能有感兴趣的文章
Oracle缩表空间的完整如何解决实例

详解Oracle控制文件及日志文件的管理问题

oracle指定类型和指定位数创建序列号的代码详解

Oracle官方工具SQLDeveloper的简单如何使用

Oracle中锁(lock)的用法