28
2024
08
18:08:33

phpMyAdmin管理mysql中 “多余”这一列是做什么用的?

见下图中的红框部分
clipboard.png

简单的说,mysql 的伎俩:以空间换时间

------ 2015年12月2日09:02:09 更新 ------------

由于我没有深入研究过 MySQL 源码,以下内容纯属猜测。

如果是 innodb 表,那么请看这个帖子 http://segmentfault.com/q/1010000000094534

我看了你的截图,表都是 MyISAM 的。在第一次插入数据的时候,数据都是连续存储的(物理存储)。当 MySQL 删除数据的时候,就会产生很多不连续的空白空间。

而当插入数据时,会有很多的策略来使用这些空白空间。我们假设其中的一种是“最旧最匹配策略”:

如果插入的数据比2大,但是比1小,那么我们就可以把他插入到1的位置。但是由于新插入的空间比1小,所以1的空间还是有剩余。

MySQL 可以防止这些碎片吗?当然可以。在删除或者插入的时候,可以把后面的所有空间前移,这样就不会产生碎片了。但是,如果表里有10万条记录,我们删除了第100条,那么我们几乎要移动所有的空间,这样就产生了非常大的IO操作。

不仅仅是 MySQL,就连 Windows 都需要定期的清理磁盘碎片。

你可以再温习一下《操作系统》课程的相关知识。





推荐本站淘宝优惠价购买喜欢的宝贝:

image.png

本文链接:https://hqyman.cn/post/7821.html 非本站原创文章欢迎转载,原创文章需保留本站地址!

分享到:
打赏





休息一下~~


« 上一篇 下一篇 »

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

请先 登录 再评论,若不是会员请先 注册

您的IP地址是: