唯一索引普通索引选择难题

唯一索引用不了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次数。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值