关于如何oracle中快速清除表中的数据

在oracle中,对于数据库中的大数据量在delete时,速度那是至关的慢。其实能够有另外的删除数据的方法,就是可使用truncate来删除表中的数据。但这种方法在删除时,虽然速度比delete快不少。但因为是不可回滚的,所以在truncate后,数据是没法恢复的。这一点很重要,必定要记牢。
     
       下面,咱们来了解一下为何truncate会比delete快不少。

       它们都是删除表中的数据,而不能删除表结构,delete 能够删除整个表的数据也能够删除表中某一条或N条知足条件的数据,而truncate只能删除整个表的数据,通常咱们把delete 操做收做删除表,而truncate操做叫做截断表。

       truncate操做与delete操做对比
   操做             回滚         高水线       空间           效率
   Truncate     不能         降低           回收             快
   delete         能够           不变       不回收           慢



下面分别用实例查看它们的不一样
一、回滚

首先要明白两点
1.在oracle 中数据删除后还能回滚是由于它把原始数据放到了undo表空间,
2.DML语句使用undo表空间,DDL语句不使用undo,而delete是DML语句,truncate是DDL语句,别外DDL语句是隐式提交.
因此truncate操用不能回滚,而delete操做能够.


二、高水线

全部的Oracle表都有一个容纳数据的上限(很象一个水库历史最高的水位),咱们把这个上限称为“high water mark”或HWM。这个HWM是一个标记(专门有一个数据块用来记录高水标记等),用来讲明已经有多少数据块分配给这个表. HWM一般增加的幅度为一次5个数据块.
delete语句不影响表所占用的数据块, 高水线(high watermark)保持原位置不动
truncate 语句缺省状况下空间释放,除非使用reuse storage;     truncate会将高水线复位


高水线的做用: HWM对数据库的操做有以下影响:
a) 全表扫描一般要读出直到HWM标记的全部的属于该表数据库块,即便该表中没有任何数据。
b) 即便HWM如下有空闲的数据库块,键入在插入数据时使用了append关键字,则在插入时使用HWM以上的数据块,此时HWM会自动增大。
所以高水线是oracle优化时一个重要的参数



三、空间

既然高水线用来讲明已经有多少数据块分配给这个表,那么高水线也可理解为表的空间占用。
即便delete将表中的数据所有删除,HWM仍是为原值,因此还有那么多的空间分配给这个表,即它的空间尚未回收,
而truncate表后高水线变为0,那如今它就表示没有分配空间,即它的空间被回收了。


四、效率
在相同的数据量删除的状况下,truncate会比delete快几十倍。这个在真实的环境中测试过。


       另外,在truncate时,当表中有主外键约束时,会抛出以下的错误:
       truncate table table_name * ERROR 位于第 1 行: ORA-02266: 表中的惟一/主键被启用的外部关键字引用。

       处理此问题的整体思路是:先将表中的主外键设置为不可用,设置成功后,则就能够truncate了。truncate后,必定要再次将主外键设置为可用。不然可能引起其余重大问题哦!
         具体处理方法以下:
         alter table table_name disable primary key cascade; --表已更改。
         truncate table table_name; --表已截掉。
         alter table table_name enable primary key;-- 表已更改。