drop、truncate和delete的区别

原地址:支照

@ drop trucate delete
数据 删除 删除 删除
结构 删除 不改变 不改变
表空间 全部释放 还原初始大小 不改变
回滚 不支持 不支持 支持
速度
使用范围 all table&view table
> 总结:

1、在速度上,一般来说,drop> truncate > delete。

2、在使用drop和truncate时一定要注意,虽然可以恢复,但为了减少麻烦,还是要慎重。

3、如果想删除部分数据用delete,注意带上where子句,回滚段要足够大;

   如果想删除表,当然用drop; 

   如果想保留表而将所有数据删除,如果和事务无关,用truncate即可;

   如果和事务有关,或者想触发trigger,还是用delete;

   如果是整理表内部的碎片,可以用truncate跟上reuse stroage,再重新导入/插入数据。

你可能感兴趣的:(Oracle)