参考资料:
参考视频https://www.bilibili.com/video/BV1jA411A7qo?p=117
参考文章 https://blog.csdn.net/shenjian58/article/details/93691224
官方文档 https://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对非索引列不起作用(不要问为什么,官方文档就是这么说的,代码是人家写的)。