• 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 操作。

Mysql

查看表占用硬盘空间大小的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='表名'

SELECT TABLE_NAME, (DATA_LENGTH+INDEX_LENGTH)/1024/1024/1024 as size_Gb, TABLE_ROWS FROM information_schema.tables WHERE TABLE_SCHEMA='radiance_prod' AND TABLE_NAME='product_info_translations';
  • 删除时候
DELETE FROM table_name WHERE id < 10000;

id = ProductInfoTranslation.first.id + 100000
ProductInfoTranslation.find(id).created_at.to_s
ProductInfoTranslation.where('id < ?', id).delete_all
  • 优化表,整理碎片
optimize table  table_name;

OPTIMIZE TABLE `product_info_translations`;

User.find_by_sql("OPTIMIZE TABLE product_info_translations")

Postgresql

  • 查看表大小
# 查询单个数据库大小
User.find_by_sql("select pg_size_pretty(pg_database_size('qi_xiang_prod')) as size;")
# 查询所有表的总大小,包括其索引大小
User.find_by_sql('select relname, pg_size_pretty(pg_total_relation_size(relid)) as size from pg_stat_user_tables order by pg_total_relation_size(relid);')
  • 优化表,整理碎片
vacuum full table_name;

vacuum full product_info_translations;

User.find_by_sql("vacuum full product_info_translations;")
  • 在 PostgreSQL 中,有几种类型的 VACUUM:

VACUUM: 用于释放未使用空间,并更新表的统计信息。
VACUUM FULL: 执行更彻底的清理,会重写整个表并释放未使用的空间。但是 VACUUM FULL 会锁定整个表,可能会影响数据库的可用性,因此需谨慎使用。
ANALYZE: 单独执行统计信息更新,而不进行空间释放。这可以单独执行而无需执行 VACUUM。

Logo

腾讯云面向开发者汇聚海量精品云计算使用和开发经验,营造开放的云计算技术生态圈。

更多推荐