简单范例

create or replace procedure delete_table
is
i number(10);
begin
for x in (select * from emp where DEPTNO like 'a%')
loop
delete emp where emp.id = x.id
i:=i+1;
if i>1000 then
commit;
i:=0;
end if;
end loop;
exception
when others then
dbms_out.put_line(sqlcode);
rollback;
end delete_table;

  Oracle中删除超过50w条记录的数据,如果直接使用delete,效率就严重受到了影响。那么首先我们需要了解对于这个表的数据,我们到底是全部删除,还是部分删除。这里有三个关键字我们需要注意:truncate,delete,drop,他们之间的异同点可以参考这篇文章——truncate,delete,drop的异同点

  全部删除,不保留数据结构就直接drop最好。如果是部分删除,一般就这样一些办法:

  1. 如果删除的数据是大部分,分段提交删除的数据。

create or replace procedure 
delete_table is i number(10); 
begin   
for x in (select * from emp where DEPTNO like ‘a%’)   
loop       
delete emp where emp.id = x.id i:=i+1;       
if i>1000 then          
commit;          
i:=0;       
end if;   
end loop; 
exception when others then dbms_out.put_line(sqlcode);
rollback
end delete_table;

  或者

–每500条数据提交一次
DECLARE CNT NUMBER(10):=0; 
I NUMBER(10); 
BEGIN 
SELECT COUNT(*) INTO CNT FROM ep_arrearage_bak 
WHERE TO_CHAR(DF_DATE,‘MM’)=’01′; 
FOR I IN 1..TRUNC(CNT/500)+1 
LOOP 
DELETE FROM ep_arrearage_bak WHERE TO_CHAR(DF_DATE,‘MM’)=’01′ ANDROWNUM<=500; 
COMMIT
END LOOP; 
END;

  2、把要保留的数据放在一个临时表里,truncate table原表后再放回来;

create table t_back as select * from t where ….
drop table t;
rename t_back to t;

  3. 专门使用一个大回滚段 ,比如定义:undo tablespace 2G

  4、如果将方法1做一点修改,可以这么做:

有条件的分步删除数据表中的记录

–创建测试表 
create table test as select * from dba_objects;

–创建删除表的存储过程  
create or replace procedure deleteTab

–插入语句    
SQLinsert into test select * from dba_objects; 
6374 rows created. 
SQL> / 6374 rows created. 
SQL> / 6374 rows created. 
SQLcommit
– 创建删除的存储过程 
create or replace procedure deleteTab
/**    
** Usage: run the script to create the proc deleteTab    
**        in SQL*PLUS, type "exec deleteTab(‘Foo’,'ID>=1000000′,’3000′);"    
**        to delete the records in the table "Foo", commit per 3000 records.    
**       Condition with default value ’1=1′ and default Commit batch is 10000.    
**/   
(p_TableName in varchar2,    – The TableName which you want to delete from     
p_Condition in varchar2 default ’1=1′,    – Delete condition, such as "id>=100000"     
p_Count in varchar2 default ’10000′    – Commit after delete How many records)   
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;   /

–执行语句 
SQLexec deleteTab(‘TEST’,‘object_id >0′,’10000′)

java_Oralce的更多相关文章

随机推荐

  1. AWR

    Automatic Workload Repository是10g引入的一个重要组件.在里面存贮着近期一段时间内,默认是7天,数据库活动状态的详细信息 手动得到一份AWR报告: SQL> exe ...

  2. quick-x在windows平台打包加密文件

    D:\quick-cocos2d-x-2.2.1-rc\bin>compile_scripts -i ..\mygames\myth\scripts -o ..\mygames\myth\res ...

  3. java 复习003 之排序篇

    由java 复习003跳转过来的C语言实现版见some-sort-algorithms 快速排序(不稳定 O(n log n)) package vell.bibi.sort_algorithms; ...

  4. TCPSocket v1.0 for cocos2d-x下载

    下载地址:http://files.cnblogs.com/elephant-x/TCPSocketLibs_V1.0.rar 这是自己封装的一个TCPSOCKET包,是独立于cocos2d-x的,使 ...

  5. HDU5734:Acperience(方差)

    题意: 给出n个数xi,确定一个值α,使得Σ(xi-α)^2的值最小. 分析: 可以猜想是方差,不懂得可以去方差了解一下. 那么α即为∑(xi)/n,然后要注意的是转化为分数,首先我们不能用小数转分数 ...

  6. 【SPOJ】Transposing is even more fun!

    题意: 给出a.b 表示按先行后列的方式储存矩阵 现在要将其转置 可以交换两个点的位置 求最小操作次数 题解: 储存可以将其视为拉成一条链 设a=5.b=2 则在链上坐标用2^***(a,b)表示为( ...

  7. HDU 5623 KK's Number (博弈DP)

    KK's Number 题目链接: http://acm.hust.edu.cn/vjudge/contest/121332#problem/K Description Our lovely KK h ...

  8. ADUM1201在隔离RS232中的应用 【瓦特芯收藏】

    ADUM1201在隔离RS232中的应用 引言: RS-232是PC机与工业通信中应用最广泛的一种串行接口.RS-232接口最初是由美国EIA(电子工业联合会)规定的用于计算机与终端设备之间通讯的一种 ...

  9. Win7关机出现关闭程序提示框

    运行输入Gpedit.msc回车打开组策略,在左侧选计算机配置/管理模板/系统/关机选项,在右侧双击“关闭会阻止或取消关机的应用程序的自动终止功能”,在打开的提示框中选“已启用”,按确定即可.

  10. [转]Oracle关于null的处理

    转至:http://www.2cto.com/database/201209/157606.html 关于空值null的排序问题   Oracle排序中NULL值处理的五种常用方法:    1.缺省O ...