每天一个开发小知识。
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。
truncate table your_tablename;
optimize table your_tablename;
通过 use information_schema 查看表空间大小; 通过 delete/truncate 删除不需要的数据; 通过 optimize 立即释放 MySQL 不需要的空间。
文章转载自每天一个开发小知识,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
【MySQL 30周年庆】MySQL 8.0 OCP考试限时免费!教你免费领考券
墨天轮小教习
3270次阅读
2025-04-25 18:53:11
MySQL 30 周年庆!MySQL 8.4 认证免费考!这次是认真的。。。
严少安
904次阅读
2025-04-25 15:30:58
【活动】分享你的压箱底干货文档,三篇解锁进阶奖励!
墨天轮编辑部
532次阅读
2025-04-17 17:02:24
MySQL 9.3 正式 GA,我却大失所望,新特性亮点与隐忧并存?
JiekeXu
456次阅读
2025-04-15 23:49:58
3月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
382次阅读
2025-04-15 14:48:05
MySQL 8.0 OCP 1Z0-908 考试解析指南(二)
JiekeXu
349次阅读
2025-04-30 17:37:37
记录MySQL数据库的一些奇怪的迁移需求!
陈举超
302次阅读
2025-04-15 15:27:53
SQL优化 - explain查看SQL执行计划(下)
金同学
296次阅读
2025-05-06 14:40:00
MySQL 30 周年庆!MySQL 8.4 认证免费考!这次是认真的。。。
数据库运维之道
290次阅读
2025-04-28 11:01:25
MySQL 8.0 OCP 1Z0-908 考试题解析指南
青年数据库学习互助会
287次阅读
2025-04-30 12:17:54