详解mysql delete删除记录数据库空间不减少问题三种解决方法

详解mysql delete删除记录数据库空间不减少问题三种解决方法

游戏|数码彩彩2024-01-02 7:30:08401A+A-

概述

MySQL里delete方式删除数据,也存在类似oracle一样高水位的问题,表空间不释放,下面是收集的几种回收方式,供供大家参考。


01

使用 OPTIMIZE

命令语法:

OPTIMIZE [LOCAL | NO_WRITE_TO_BINLOG] TABLE tbl_name [, tbl_name] ...

最简单的命令:

OPTIMIZE table act_demo_test;
详解mysql delete删除记录数据库空间不减少问题三种解决方法

 

如果已经删除了表的一大部分,或者如果已经对含有可变长度行的表(含有VARCHAR, BLOB或TEXT列的表)进行了很多更改,则应使用 OPTIMIZE TABLE。

被删除的记录被保持在链接清单中,后续的INSERT操作会重新使用旧的记录位置。可以使用OPTIMIZE TABLE来重新 利用未使用的空间,并整理数据文件的碎片。

注意:

在OPTIMIZE TABLE运行过程中,MySQL会锁定表。因此,这个操作一定要在网站访问量较少的时间段进行。

一个37G的表,耗时5s,时间仅作参考,和服务器性能有关。


02

使用Alter命令

相当于删除旧表,建立新表。

例如:

mysql> alter table tablename engine=innodb;
详解mysql delete删除记录数据库空间不减少问题三种解决方法

 

一个37G的表,耗时7s,时间仅作参考,和服务器性能有关。


03

导出导入

利用mysqldump导出数据,然后再重新导入数据。

详解mysql delete删除记录数据库空间不减少问题三种解决方法

 

mysqldump导出表语法:

mysqldump -u用户名 -p密码 -h主机 数据库 表

例子:

mysqldump -uroot -p sqlhk9 a --no-data

注意:

这种方式会影响业务正常使用,不推荐。
 

点击这里复制本文地址 版权声明:本文内容由网友提供,该文观点仅代表作者本人。本站(https://www.angyang.net.cn)仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件举报,一经查实,本站将立刻删除。

昂扬百科 © All Rights Reserved.  渝ICP备2023000803号-3网赚杂谈