码迷,mamicode.com
首页 > 数据库 > 详细

Oracle truncate和delete的区别

时间:2014-11-17 21:04:33      阅读:214      评论:0      收藏:0      [点我收藏+]

标签:ar   sp   数据   bs   nbsp   c   oracle   信息   测试   

首先truncate是DDL语句,而delete是DML语句。

truncate的删除比delete快很多,尤其是表数据量大的时候,原因是truncate执行过程中不产生undo,所以truncate也无法再回滚。而delete在commit之前肯定是可以回滚的。

truncate的另一个特性是会将表的高水位线重新归零,delete不会这样做,这也是truncate的一个优点,全表扫描仅搜索位于高水位线之下的存储块中的数据行。这对于全表扫描性能具有很大影响。

truncate有一个副作用,如果一张表定义了主键,并且这个主键是其子表的外键,那么不能truncate这张表,即使子表没有任何数据。这种情况下试图去truncate会报:OAR-02266。原因是truncate无法回滚,防止有人并发往子表插入数据。而delete是允许这样做的,因为delete会生成重做信息,具有读一致性,并且能够回滚。

 

最后还有一种删除全表数据的方式:drop表并且重建,这种情况一般不会在生产环境做,多用于开发测试阶段。

Oracle truncate和delete的区别

标签:ar   sp   数据   bs   nbsp   c   oracle   信息   测试   

原文地址:http://www.cnblogs.com/attlia/p/4104234.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!