位置: 编程技术 - 正文
推荐整理分享MySQL 清除表空间碎片的实例详解(mysql清空表内容),希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:清空mysql数据表,mysql如何清空表,mysql清空表数据sql语句,mysql清空表内容,mysql 清空表 sql,mysql清理表空间,mysql清理表空间,mysql怎么清空表中数据,内容如对您有帮助,希望把文章链接给更多的朋友!
MySQL 清除表空间碎片的实例详解
碎片产生的原因
(1)表的存储会出现碎片化,每当删除了一行内容,该段空间就会变为空白、被留空,而在一段时间内的大量删除操作,会使这种留空的空间变得比存储列表内容所使用的空间更大;
(2)当执行插入操作时,MySQL会尝试使用空白空间,但如果某个空白空间一直没有被大小合适的数据占用,仍然无法将其彻底占用,就形成了碎片;
(3)当MySQL对数据进行扫描时,它扫描的对象实际是列表的容量需求上限,也就是数据被写入的区域中处于峰值位置的部分;
例如:
一个表有1万行,每行字节,会占用万字节存储空间,执行删除操作,只留一行,实际内容只剩下字节,但MySQL在读取时,仍看做是万字节的表进行处理,所以,碎片越多,就会越来越影响查询性能。
查看表碎片大小
(1)查看某个表的碎片大小
结果中'Data_free'列的值就是碎片大小
(2)列出所有已经产生碎片的表
清除表碎片
(1)MyISAM表
(2)InnoDB表
Engine不同,OPTIMIZE 的操作也不一样的,MyISAM 因为索引和数据是分开的,所以 OPTIMIZE 可以整理数据文件,并重排索引.
OPTIMIZE 操作会暂时锁住表,而且数据量越大,耗费的时间也越长,它毕竟不是简单查询操作.所以把 Optimize 命令放在程序中是不妥当的,不管设置的命中率多低,当访问量增大的时候,整体命中率也会上升,这样肯定会对程序的运行效率造成很大影响.比较好的方式就是做个shell,定期检查mysql中 information_schema.TABLES字段,查看 DATA_FREE 字段,大于0话,就表示有碎片
建议
清除碎片操作会暂时锁表,数据量越大,耗费的时间越长,可以做个脚本,定期在访问低谷时间执行,例如每周三凌晨,检查DATA_FREE字段,大于自己认为的警戒值的话,就清理一次。
如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
Ubuntu下MySQL安装及配置远程登录教程 本文实例为大家分享了MySQL安装及配置远程登录教程,供大家参考,具体内容如下一.安装MySQL一.安装MySQL1.sudoapt-getinstallmysql-server2.sudoapt-getinstallmysql-clien
MySQL分区字段列有必要再单独建索引吗? 前言大家都知道对于分区字段必须是主键的一部分,那么建了复合主键之后,是否需要对分许字段再单独添加一个索引呢?有没有效果?来验证一下,
Windows下Mysql启动报的解决方法 前几天刚入职安装了一下Mysql刚开始能打开。今天去公司发现启动不了服务报错误,在网上查看了一些方法,好多种版本,以下是本人的解决方法:1.
标签: mysql清空表内容
本文链接地址:https://www.jiuchutong.com/biancheng/348303.html 转载请保留说明!友情链接: 武汉网站建设