删除用户会释放表空间么_mysql delete删除记录数据库空间还是不减少?试试这三个办法...

概述

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


01

使用 OPTIMIZE

命令语法:

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

最简单的命令:

OPTIMIZE table act_demo_test;
d68e1b2ee867a8e147a381e2eac83cb1.png

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

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

注意:

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

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


02

使用Alter命令

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

例如:

mysql> alter table tablename engine=innodb;
648de34d258a88193617412571178241.png

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


03

导出导入

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

8abdf47caeaab2bf4b2e84241804e053.png

mysqldump导出表语法:

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

例子:

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

注意:

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


后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注一下~

e004c9c8c090045fd8b4bd04cb48b063.gif
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值