delete和truncate差别
时间: 2023-08-29 08:10:32 浏览: 122
引用\[1\]:在功能上,truncate是清空一个表的内容,它相当于delete from table_name。而delete是dml操作,truncate是ddl操作;因此,用delete删除整个表的数据时,会产生大量的roolback,占用很多的rollback segments,而truncate不会。\[1\]引用\[2\]:在没有备份情况下,谨慎使用drop与truncate。要删除部分数据行采用delete且注意结合where来约束影响范围。要删除表用drop;若想保留表而将表中数据删除,如果于事务无关,用truncate即可实现。如果和事务有关,或想触发trigger,还是用delete。\[2\]引用\[3\]:相同点是truncate和delete都会删除表内的数据,不同点是:1. truncate和delete只删除数据不删除表的结构(定义),而drop语句将删除表的结构被依赖的约束(constrain),触发器(trigger),索引(index);依赖于该表的存储过程/函数将保留,但是变为invalid状态。2. delete语句是dml操作,这个操作会放到rollback segment中,事务提交之后才生效;如果有相应的trigger,执行的时候将被触发。而truncate和drop是ddl操作,操作立即生效,原数据不放到rollback segment中,不能回滚,操作也不触发trigger。3. delete语句不影响表所占用的extent,高水线(high watermark)保持原位置不动,而drop语句将表所占用的空间全部释放,truncate语句缺省情况下将空间释放到minextents个extent,除非使用reuse storage;truncate会将高水线复位(回到最开始)。4. 速度上,一般来说:drop > truncate > delete。5. 安全性上,要小心使用drop和truncate,尤其没有备份的时候。如果想删除部分数据行,可以使用delete,并注意带上where子句。回滚段要足够大。如果想删除表,当然可以使用drop。如果想保留表而将所有数据删除,如果和事务无关,可以使用truncate。如果和事务有关,或者想触发trigger,还是使用delete。\[3\]
所以,delete和truncate的差别主要在以下几个方面:
1. 功能上:truncate相当于delete from table_name,但truncate是ddl操作,而delete是dml操作。
2. 影响范围:delete会产生大量的roolback,占用很多的rollback segments,而truncate不会。
3. 数据结构:delete只删除数据,不删除表的结构,而drop语句会删除表的结构和依赖的约束、触发器、索引;truncate只删除数据,不删除表的结构。
4. 回滚和触发器:delete操作会放到rollback segment中,事务提交之后才生效,并且会触发相应的trigger;而truncate和drop操作立即生效,不放到rollback segment中,也不触发trigger。
5. 空间释放:delete不影响表所占用的extent,高水线保持原位置不动;drop会释放表所占用的全部空间;truncate缺省情况下将空间释放到minextents个extent。
6. 速度:一般来说,drop > truncate > delete。
7. 安全性:使用drop和truncate时要小心,尤其没有备份的情况下。如果想删除部分数据行,可以使用delete,并注意带上where子句。如果想删除整个表,可以使用drop。如果想保留表而将所有数据删除,如果和事务无关,可以使用truncate。如果和事务有关,或者想触发trigger,还是使用delete。
#### 引用[.reference_title]
- *1* *3* [delete和truncate的区别](https://blog.csdn.net/weixin_42981419/article/details/86162133)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item]
- *2* [drop、truncate和delete的区别](https://blog.csdn.net/ws0513/article/details/49980547)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item]
[ .reference_list ]
阅读全文