上犹电脑信息网我们一直在努力
您的位置:上犹电脑信息网 > 电脑怎么了 > 怎么删除空间访问记录-mysql delete删除记录数据库空间还是不减少?试试这三个办法

怎么删除空间访问记录-mysql delete删除记录数据库空间还是不减少?试试这三个办法

作者:上犹日期:

返回目录:电脑怎么了

概述

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



01

使用 OPTIMIZE

命令语法:


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

最简单的命令:


OPTIMIZE table act_demo_test;

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


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


注意:


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


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



02

使用Alter命令

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


例如:


mysql> alter table tablename engine=innodb;

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



03

导出导入

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


mysqldump导出表语法:


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

例子:


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

注意:


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



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




相关阅读

  • ORACLE 常见故障恢复-dnf文件损坏

  • 上犹文件问题
  • dnf文件损坏,故障现象丢失某个数据库文件,造成了数据库无法启动。DBF'l解决方法将数据库启动到mount状态下:SQLplus“/assysdba”startupmount从数据库中删除该数据文件alterdatabasedatafil
关键词不能为空
极力推荐

电脑蓝屏_电脑怎么了_win7问题_win10问题_设置问题_文件问题_上犹电脑信息网

关于我们