关于如何oracle中快速清除表中的数据
在oracle中,对于数据库中的大数据量在delete时,速度那是相当的慢。其实可以有另外的删除数据的方法,就是可以使用truncate来删除表中的数据。但这种方法在删除时,虽然速度比delete快很多。但由于是不可回滚的,因此在truncate后,数据是无法恢复的。这一点很重要,一定要记牢。
下面,我们来了解一下为什么truncate会比delete快很多。
它们都是删除表中的数据,而不能删除表结构,delete 可以删除整个表的数据也可以删除表中某一条或N条满足条件的数据,而truncate只能删除整个表的数据,一般我们把delete 操作收作删除表,而truncate操作叫作截断表。
truncate操作与delete操作对比
操作 回滚 高水线 空间 效率
Truncate 不能 下降 回收 快
delete 可以 不变 不回收 慢
下面分别用实例查看它们的不同
1、回滚
首先要明白两点
1.在oracle 中数据删除后还能回滚是因为它把原始数据放到了undo表空间,
2.DML语句使用undo表空间,DDL语句不使用undo,而delete是DML语句,truncate是DDL语句,别外DDL语句是隐式提交.
所以truncate操用不能回滚,而delete操作可以.
2、高水线
所有的Oracle表都有一个容纳数据的上限(很象一个水库历史最高的水位),我们把这个上限称为“high water mark”或HWM。这个HWM是一个标记(专门有一个数据块用来记录高水标记等),用来说明已经有多少数据块分配给这个表. HWM通常增长的幅度为一次5个数据块.
delete语句不影响表所占用的数据块, 高水线(high watermark)保持原位置不动
truncate 语句缺省情况下空间释放,除非使用reuse storage; truncate会将高水线复位
高水线的作用: HWM对数据库的操作有如下影响:
a) 全表扫描通常要读出直到HWM标记的所有的属于该表数据库块,即使该表中没有任何数据。
b) 即使HWM以下有空闲的数据库块,键入在插入数据时使用了append关键字,则在插入时使用HWM以上的数据块,此时HWM会自动增大。
因此高水线是oracle优化时一个重要的参数
3、空间
既然高水线用来说明已经有多少数据块分配给这个表,那么高水线也可理解为表的空间占用。
即使delete将表中的数据全部删除,HWM还是为原值,所以还有那么多的空间分配给这个表,即它的空间还没有回收,
而truncate表后高水线变为0,那现在它就表示没有分配空间,即它的空间被回收了。
4、效率
在相同的数据量删除的情况下,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;-- 表已更改。