手机
当前位置:查字典教程网 >编程开发 >Oracle教程 >Oracle中大批量删除数据的方法
Oracle中大批量删除数据的方法
摘要:写一个循环删除的过程。createorreplaceproceduredelBigTab(p_TableNameinvarchar2,p_C...

写一个循环删除的过程。

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中大批量删除数据的方法】相关文章:

oracle11g创建数据库的方法

oracle中decode函数

Oracle 数据表分区的策略

oracle概念-数据库文件概述

Oracle中相关函数说明

Oracle7.X 回滚表空间数据文件误删除处理方法

Oracle跨服务器查询插入数据

Oracle增量备份的机制

Oracle中如何恢复被删掉的存储过程?

OracleDataGuard_主库重命名数据文件

精品推荐
分类导航