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

发布于 2022-09-01 21:53:46 字数 150 浏览 20 评论 0

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

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

随风而去 2022-09-08 21:53:46

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

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

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

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

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

clipboard.png

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

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

clipboard.png

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

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

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

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文