当前位置: 首页 > 图文教程 > 数据库 > Oracle > Oracle中大批量删除数据的方法

Oracle
Oracle:小编浅谈把文本文件导入oracle
Oracle:小编概述数据库安全性
ORACLE常见错误代码的分析与解决(一)
Oracle7.X 回滚表空间数据文件误删除处理方法
Oracle数据库的备份与恢复
常见数据库系统比较 Oracle数据库
在Linux下安装Oracle
怎么才能限制SQL Server只能让指定的机器连接
Oracle 8i在P4上的安装
oracle初始化参数设置
Oracle性能究极优化 下
Oracle性能究极优化
Oracle性能究极优化 上
Oracle如何直接运行OS命令(下)
Oracle如何直接运行OS命令(上)
Oracle数据库安全策略分析 (三)
Oracle数据库安全策略分析(二)
Oracle数据库安全策略分析(一)
自动备份Oracle数据库
ORACLE常见错误代码的分析与解决(二)

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-13   浏览: 52 ::
收藏到网摘: n/a

写一个循环删除的过程。
create or replace procedure delBigTab(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 <= :10000'
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 delBigTab;
调用:
SQL> set timing on
SQL> exec delBigTab('HS_DLF_DOWNLOG_HISTORY','NUMDLFLOGGUID < 11100000','10000');
PL/SQL procedure successfully completed.
Elapsed: 00:00:18.54
方法虽好,但我应用在一个亿级数据库时还是觉得慢得不行。就算删一点点数据也觉得好象挺慢的。