MySQL删除语句比较,清空表数据,重置自增长索引

drop truncate delete 程度从强到弱

1、drop table tb
drop将表格直接删除,没有办法找回

2、truncate (table) tb
truncate 删除表中的所有数据,不能与where一起使用

3、delete from tb (where)
delete 删除表中的数据(可制定某一行)

truncate和delete的区别

① 事务:truncate是不可以rollback的,但是delete是可以rollback的;

在执行速度上,drop>truncate>delete

原因:truncate删除整表数据(ddl语句,隐式提交),delete是一行一行的删除,可以rollback
② 效果:truncate删除后将重置索引(自增长id从零开始) ,delete不会删除索引
③ truncate 不能触发任何Delete触发器。
④ delete 删除可以返回行数

 

 

TRUNCATE语句和DELETE语句的区别

1、delete语句,是DML语句,truncate语句通常被认为是DDL语句。

2、delete语句,后面可以跟where子句,通常指定where子句中的条件表达式,只删除满足条件的部分记录,而truncate语句,只能用于删除表中的所有记录。

3、truncate语句,删除表中的数据后,向表中添加记录时,自动增加字段的默认初始值重新从1开始,而使用delete语句,删除表中所有记录后,向表中添加记录时,自动增加字段的值,为删除时该字段的最大值加1,也就是在原来的基础上递增。

4、delete语句,每删除一条记录,都会在日志中记录,而使用truncate语句,不会在日志中记录删除的内容,因此,truncate语句的执行效率比delete语句高。

posted @ 2019-06-19 11:56  牛奔  阅读(2605)  评论(0编辑  收藏  举报