phpMyAdmin管理mysql中 “多余”这一列是做什么用的?
大家讲道理
大家讲道理 2017-04-17 13:30:59
[MySQL讨论组]

见下图中的红框部分

大家讲道理
大家讲道理

光阴似箭催人老,日月如移越少年。

全部回复(1)
PHP中文网

简单的说,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 都需要定期的清理磁盘碎片。

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

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号