mysql表空间释放状况汇总

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

mysql表空间释放状况汇总

mysql表空间释放状况汇总