MySQL InnoDB的插入缓冲Insert Buffer

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】,是不是很可爱呢😄以后还是会有越来越多推文的,老铁们不要取关哦❤️

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值