InnoDB之change buffer

参考资料:

参考视频icon-default.png?t=M4ADhttps://www.bilibili.com/video/BV1jA411A7qo?p=117

参考文章 icon-default.png?t=M4ADhttps://blog.csdn.net/shenjian58/article/details/93691224

官方文档 icon-default.png?t=M4ADhttps://dev.mysql.com/doc/refman/8.0/en/innodb-change-buffer.html


change buffer 介绍:

 

  • change buffer 是为了提升buffer pool对非唯一索引的增删改速度而创建的,change buffer属于buffer pool,空间从buffer pool分配,具体机制如下:
  • 我们知道,InnoDB存储数据,是以B+树形式,以16KB为一页进行存储,分为聚簇索引和非聚簇索引两种,即使我们不设置索引,也会有默认的聚簇索引帮我们整理数据。其中聚簇索引存储着全部数据,非聚簇索引只存储主键以及该索引值;
  • 所以,所有的数据都在聚簇索引(主键索引)上,非聚簇索引只包含索引值及主键值;

 

  •  当我们对数据进行查询时,innoDB会将这些数据对应的页加载到buffer pool中,然后再返回给程序,这个毋庸置疑(buffer pool机制前面已经说过)
  • 但是当我们对数据页进行增删改操作时:
  • 如果是要修改主键索引或者唯一索引,则需要将主键索引树或者唯一索引树,以页的方式加载到buffer pool中,进行唯一性校验,然后在进行增删改操作,如
UPDATE park SET id = 3 WHERE  area = 'bj';
  • 如果是要修改 不具有唯一性的索引(如:单值索引,复合索引),就先检查buffer pool是否有该数据的页,如果有就在buffer pool进行增删改,如果没有,就没必要将对应的数据页加载到buffer pool中,使用change buffer将要增删改的数据暂存起来,如果buffer pool因为查询,加载了对应的数据页,change buffer 存储的数据就会更新到buffer pool中,当然还有其他的落盘机制:(1)有一个后台线程,会认为数据库空闲时;(2)数据库缓冲池不够用时;(3)数据库正常关闭时(4)redo log写满时;
UPDATE park SET `name` = 'peter' WHERE  id = 1;

 

  •  由于change buffer  对非唯一性索引的缓存功能,使得数据库省去了buffer pool的加载过程,大大提升了数据库增删改的效率。
  • 注意:change buffer对非索引列不起作用(不要问为什么,官方文档就是这么说的,代码是人家写的)。

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

PH = 7

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值