@ | drop | trucate | delete |
---|---|---|---|
数据 | 删除 | 删除 | 删除 |
结构 | 删除 | 不改变 | 不改变 |
表空间 | 全部释放 | 还原初始大小 | 不改变 |
回滚 | 不支持 | 不支持 | 支持 |
速度 | 快 | 中 | 慢 |
使用范围 | all | table&view | table |
> 总结:
1、在速度上,一般来说,drop> truncate > delete。
2、在使用drop和truncate时一定要注意,虽然可以恢复,但为了减少麻烦,还是要慎重。
3、如果想删除部分数据用delete,注意带上where子句,回滚段要足够大;
如果想删除表,当然用drop;
如果想保留表而将所有数据删除,如果和事务无关,用truncate即可;
如果和事务有关,或者想触发trigger,还是用delete;
如果是整理表内部的碎片,可以用truncate跟上reuse stroage,再重新导入/插入数据。