唯一索引用不了change buffer
普通索引可以使用change buffer优化
唯一索引就是例如检索K=5,K为唯一索引的话,只要扫描到K=5,就立即停止返回结果。
普通索引则扫描到结果还会继续扫描,因为可能扫描到K=5的数据行不唯一。
所谓change buffer就是:
当需要更新一个数据页时,如果数据页在内存中就直接更新,而如果这个数据页还没有在内存中的话,在不影响数据一致性的前提下,InooDB会将这些更新操作缓存在change buffer中,这样就不需要从磁盘中读入这个数据页了。
在下次查询需要访问这个数据页的时候,将数据页读入内存,然后执行change buffer中与这个页有关的操作,通过这种方式就能保证这个数据逻辑的正确性。
将change buffer中的操作应用到原数据页,得到最新结果的过程称为merge。
除了访问这个数据页会触发merge外,系统有后台线程会定期merge。在数据库正常关闭(shutdown)的过程中,也会执行merge操作。
为什么change buffer也可以保证持久性呢,是因为其也会写入redo log,万一断电,也会被redo log写入磁盘,保证持久性。
一开始让我疑惑的是这不应该是redo log做的事吗?change buffer和redo log功能是不是重复了?
其实不是的,要知道当执行一个update操作的时候,不仅有写入磁盘的过程,其实应该是读磁盘到内存,修改再写入的过程。所以,使用了change buffer可以少一次读取的过程,减少了磁盘io次数。