MySQL删除数据几种状况以及是否释放磁盘空间:mysql
一、drop table table_name 马上释放磁盘空间 ,无论是 Innodb和MyISAM ;sql
二、truncate table table_name 马上释放磁盘空间 ,无论是 Innodb和MyISAM 。truncate table其实有点相似于drop table 而后creat,只不过这个create table 的过程作了优化,好比表结构文件以前已经有了等等。因此速度上应该是接近drop table的速度;ide
三、delete from table_name删除表的所有数据,对于MyISAM 会马上释放磁盘空间 (应该是作了特别处理,也比较合理),InnoDB 不会释放磁盘空间;优化
四、对于delete from table_name where xxx带条件的删除, 无论是innodb仍是MyISAM都不会释放磁盘空间;3d
五、delete操做之后使用optimize table table_name 会马上释放磁盘空间。无论是innodb仍是myisam 。因此要想达到释放磁盘空间的目的,delete之后执行optimize table 操做。
六、delete from表之后虽然未释放磁盘空间,可是下次插入数据的时候,仍然可使用这部分空间。 blog
删除前:it