mysql中drop、truncate、delete的区别

DELETE

DELETE是一种数据操作语言(DDL)命令(CREATE 、 DROP 、 ALTER、TRUNCAT),使用DELETE 无法删除整个表的约束、索引,只删除数据。
1、每次从表中删除一行,并且同时将该行的的删除操作记录在redo和undo表空间中以便进行回滚(rollback)和重做操作,但要注意表空间要足够大,需要手动提交(commit)操作才能生效,可以通过rollback撤消操作。
2、delete可根据条件删除表中满足条件的数据,如果不指定where子句,那么删除表中所有记录

DROP

1、drop 会删除表结构及所有数据,并将表所占空间全部释放。执行后立即生效,无法找回
2、drop 回删除表的结构 以及所依赖的约束、触发器、索引等。

truncate

1、不会删除表结构
2、表数据会完全清空,并且不可以回滚
3、能够快速清空一个表。并且重置auto_increment的值。
4、对于外链约束引用的表,不能使用truncate table, 而应使用不带where 子句的 delete 语句。

  • 对于MyISAM,truncate会重置auto_increment(自增序列)的值为1。而delete后表仍然保持auto_increment。
  • 对于InnoDB,truncate会重置auto_increment的值为1。delete后表仍然保持auto_increment。但是在做delete整个表之后重启MySQL的话,则重启后的auto_increment会被置为1。
总结
  1. 从执行速度上来说 drop > truncate > DELETE
  2. 在使用drop和truncate时一定要注意,虽然可以恢复,但为了减少麻烦,还是要慎重。
  3. 如果想删除部分数据用delete,注意带上where子句,回滚段要足够大;
    如果想删除表,当然用drop;

如果想保留表而将所有数据删除,如果和事务无关,用truncate即可;

如果和事务有关,或者想触发trigger,还是用delete

你可能感兴趣的:(mysql,数据库,sql)