MySQL InnoDB关键特性(一)
插入缓冲Insert Buffer
Insert Buffer是物理页的一个组成部分
在InnoDB中,主键是行唯一的标识符,自增主键中行记录的插入顺序是按照主键递增的顺序进行插入的,故插入聚集索引一般是顺序的,不需要磁盘的随机读取。
create table t1 (
a int auto_increment,
primary key(a)
)复制
当表中有一个聚集索引和多个非聚集索引时,在进行插入操作时,数据页的存放还是按主键a进行顺序存放的,但对于非聚集索引叶子节点但插入不再是顺序的了,此时需离散地访问非聚集索引页,这种随机读取导致了插入操作性能下降。某些情况例如时间字段,非聚集索引的插入是顺序或者比较顺序的.
create table t2 (
a int auto_increment,
b varchar(255),
primary key(a),
key(b)
)复制
Insert Buffer对于非聚集索引的插入或更新操作,不是每一次直接插入到索引页中。流程如下:
merge操作中可以将多个插入/更新合并到一个操作中,提高了非聚集索引插入/更新的性能。
综上,Insert Buffer的使用需要同时满足的条件是:索引是非聚集索引且索引不是唯一的
为什么要求索引不是唯一的?
因为在插入缓冲时,数据库并不去查找索引页来判断插入记录的唯一性;如果去查找的话肯定又会发生随机读取,导致了Insert Buffer失去意义。
参考文献《MySQL技术内幕 InnoDB存储引擎(第2版)》
好久没更新推文了,最近忙完了毕业论文后可以有时间来学习一下了。女朋友把公众号的名字改成了【小猪notebook】,是不是很可爱呢😄以后还是会有越来越多推文的,老铁们不要取关哦❤️
文章转载自小猪notebook,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
【MySQL 30周年庆】MySQL 8.0 OCP考试限时免费!教你免费领考券
墨天轮小教习
2979次阅读
2025-04-25 18:53:11
MySQL 30 周年庆!MySQL 8.4 认证免费考!这次是认真的。。。
严少安
852次阅读
2025-04-25 15:30:58
【活动】分享你的压箱底干货文档,三篇解锁进阶奖励!
墨天轮编辑部
496次阅读
2025-04-17 17:02:24
MySQL 9.3 正式 GA,我却大失所望,新特性亮点与隐忧并存?
JiekeXu
436次阅读
2025-04-15 23:49:58
3月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
373次阅读
2025-04-15 14:48:05
MySQL 8.0 OCP 1Z0-908 考试解析指南(二)
JiekeXu
292次阅读
2025-04-30 17:37:37
记录MySQL数据库的一些奇怪的迁移需求!
陈举超
279次阅读
2025-04-15 15:27:53
SQL优化 - explain查看SQL执行计划(下)
金同学
274次阅读
2025-05-06 14:40:00
MySQL 8.0 OCP 1Z0-908 考试题解析指南
青年数据库学习互助会
257次阅读
2025-04-30 12:17:54
MySQL 30 周年庆!MySQL 8.4 认证免费考!这次是认真的。。。
数据库运维之道
248次阅读
2025-04-28 11:01:25