[数据库] 删除数据,释放空间

  • drop table table_name 立刻释放磁盘空间 ,不管是 Innodb和MyISAM ;

  • truncate table table_name 立刻释放磁盘空间 ,不管是 Innodb和MyISAM 。truncate table其实有点类似于drop table 然后creat,只不过这个create table 的过程做了优化,比如表结构文件之前已经有了等等。所以速度上应该是接近drop table的速度;

  • delete from table_name删除表的全部数据,对于MyISAM 会立刻释放磁盘空间 (应该是做了特别处理,也比较合理),InnoDB 不会释放磁盘空间;

  • 对于delete from table_name where xxx带条件的删除, 不管是innodb还是MyISAM都不会释放磁盘空间;

  • delete操作以后使用optimize table table_name 会立刻释放磁盘空间。不管是innodb还是myisam 。所以要想达到释放磁盘空间的目的,delete以后执行optimize table 操作。

查看表占用硬盘空间大小的SQL语句如下:(默认用G做展示单位)

SELECT TABLE_NAME, (DATA_LENGTH+INDEX_LENGTH)/1024/1024/1024 as size_Gb, TABLE_ROWS FROM information_schema.tables WHERE TABLE_SCHEMA='数据库名' AND TABLE_NAME='表名'
  • 删除时候
DELETE FROM table_name WHERE id < 10000;
optimize table  table_name;

Guess you like

Origin blog.csdn.net/qq_41037744/article/details/112692186