如何释放 MySQL 占用的磁盘空间

网友投稿 685 2022-11-03

本站部分文章、图片属于网络上可搜索到的公开信息,均用于学习和交流用途,不能代表睿象云的观点、立场或意见。我们接受网民的监督,如发现任何违法内容或侵犯了您的权益,请第一时间联系小编邮箱jiasou666@gmail.com 处理。

如何释放 MySQL 占用的磁盘空间

每天一个开发小知识。

Redis 容量满了,Redis 还能帮你删除数据,MySQL 呢?它就没这么好了。

当 MySQL 数据太多,占用磁盘空间太大时,我们该怎么办?

首先,我们要找出占用磁盘空间大的表:

use information_schema;SELECT TABLE_NAME,TABLE_ROWS,DATA_LENGTH+INDEX_LENGTH,concat(round((DATA_LENGTH+INDEX_LENGTH)/1024/1024,2), 'MB') as data FROM TABLES WHERE TABLE_SCHEMA='your_database' and table_name='your_tablename';

其中,your_database 是你指定的数据库名,your_tablename 是你指定的表名。

如果你能猜出是哪张表大概率占用空间大,你可以指定 table_name,如果你不想指定,去掉 table_name = 'your_table' 即可。

该语句的输出结果:

第一列:表名;第二列:该表的行数;第三列:该表占用空间大小,单位 B;第四列:该表占用空间大小,单位 MB。

这时,我们知道了哪张表占用空间大,如果该表可以整个清空,那就不要使用 delete 命令,而是:

truncate table your_tablename;

因为 truncate 的速度会比 delete 快很多。

当你使用完 delete/truncate 操作,再使用 information_schema 查看表空间大小,会发现该表大小并没有减少。

这是因为你还需要执行下面语句,使 MySQL 立即释放不需要的空间:

optimize table your_tablename;

总结,释放 MySQL 占用的磁盘空间,一共三步:

通过 use information_schema 查看表空间大小;通过 delete/truncate 删除不需要的数据;通过 optimize 立即释放 MySQL 不需要的空间。

每天一个开发小知识,今天你学废了吗?

上一篇:软件测试培训之基于“经验”的测试用例设计
下一篇:软件测试培训之测试用例概念化
相关文章

 发表评论

暂时没有评论,来抢沙发吧~