Mysql Delete 和 truncate这两个删除的区别

Mysql Delete 和 truncate这两个删除的区别

deletetruncate
条件删除支持不支持
事物删除支持不支持
条件删除
条件删除
条件删除

条件删除

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会将高水线复位。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值