mysql中delete和truncate有哪些区别

2021年1月17日08:50:39 发表评论 78 views

delete和truncate区别如下:

一、灵活性:delete可以条件删除数据,而truncate只能删除表的所有数据;

delete from table_test where ...

truncate table table_test

二、效率:delete效率低于truncate,delete是一行一行地删除,truncate会重建表结构,

三、事务:truncate是DDL语句,需要drop权限,因此会隐式提交,不能够rollback;delete是DML语句,可以使用rollback回滚。

四、触发器:truncate 不能触发任何Delete触发器;而delete可以触发delete触发器。

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: