Mysql Delete 和 truncate这两个删除的区别
delete | truncate | |
---|---|---|
条件删除 | 支持 | 不支持 |
事物删除 | 支持 | 不支持 |
条件删除 | 慢 | 快 |
条件删除 | 慢 | 快 |
条件删除 | 否 | 是 |
条件删除
delete 和 where连用
truncate 不可以 和 where 连用
所以truncate 只能删除整个表
# delete 和 where
delete from students where id =1;
# delete 删除整个表
delete from students;
# truncate 删除整个表
truncate table students;
事物回滚
delete 可以进行rollback 事物回滚
truncate 不可以
#开启事物
start transaction;
#删除表
delete from students;
#查看是否删除
select * from students;
#回滚
rollback;
#查看回滚后表情况
select * from students;
关于事物的基础命令流程回顾
--开始事务
begins; --或者写成 start transcations;
--执sql命令
这里自己写随便的mysql命令就好了
--回滚事物
rollback;
需要注意的是:事物回滚以后,就默认提交事物了,需要从新再次打开事物
---提交事物
commit;
清理速度
数据量小,DELETE和TRUNCATE的清理速度差别不大
数据量大,TRUNCATE速度快
TRUNCATE不需要支持回滚,所以使用的系统和事务日志资源少。
DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一项,固然会慢,但是相对来说也较安全。
高水位重置
随着不断地进行表记录的DML操作,会不断提高表的高水位线(HWM),DELETE操作之后虽然删除数据,但没有降低表的高水位。
随着DML操作数据库容量也只会上升,不会下降。
使用DELETE,就算将表中的数据减少了很多,在查询时还是很和DELETE操作前速度一样。
TRUNCATE操作会重置高水位线,数据库容量也会被重置,之后再进行DML操作速度也会有提升。
关于delete和 truncate的题:
下面有关sql 语句中 delete truncate的说法正确的是?()
A. 论清理表数据的速度,truncate一般比delete更快
B. truncate命令可以用来删除部分数据。
C. truncate只删除表的数据不删除表的结构
D. delete能够回收高水位
正确答案: A C
总结
1、处理效率:drop>trustcate>delete
2、drop删除整个表;trustcate删除全部记录,但不删除表;delete删除部分记录
3、delete不影响所用extent,高水线保持原位置不动;trustcate会将高水线复位。