第七问:第八问:DELETE、DROP和TRUNCATE的区别是什么?
答案:
-
在执行速度上,一般来说,drop> truncate > delete。
-
在使用drop和truncate时一定要注意,虽然可以恢复,但为了减少麻烦,还是要慎重。
-
如果想删除部分数据用delete,注意带上where子句,回滚段要足够大;
如果想删除表,当然用drop;
如果想保留表而将所有数据删除,如果和事务无关,用truncate即可;
如果和事务有关,或者想触发trigger,还是用delete;
如果是整理表内部的碎片,可以用truncate跟上reuse stroage,再重新导入/插入数据。
测试
Drop
Truncate
Delete
20分钟。。。