开发者社区 > 数据库 > 正文

当InnoDB 引擎试图读取数据页时,会利用缓冲池实例的散列表进行查找,并分几种情况处理?

已解决

当InnoDB 引擎试图读取数据页时,会利用缓冲池实例的散列表进行查找,并分几种情况处理?

展开
收起
云上静思 2022-09-19 19:57:48 325 0
1 条回答
写回答
取消 提交回答
  • 推荐回答

    分三种情况处理:

    • 当在散列表中定位到,即数据页在LRU List 中时,会判断数据页是在Old 区还是Young 区,如果数据页存在于Old 区,则在读取完数据页后把它添加到Young 区的链表头部。

    • 如果在散列表中定位到并且数据页在Young 区,则需要判断数据页所在Young 区的位置,只有数据页处于Young 区总长度大约1/4 的位置之后,才会将其添加到Young 区的链表头部。

    • 如果未能在散列表定位到,则需要在数据文件中读取数据页,并将其添加到Old 区的链表头部。

    以上内容摘自《云原生数据库原理与实践》,这本书可以在电子工业出版社天猫店购买。

    2022-09-19 20:49:41
    赞同 展开评论 打赏

数据库领域前沿技术分享与交流

相关电子书

更多
PostgresChina2018_赖思超_PostgreSQL10_hash索引的WAL日志修改版final 立即下载
事务、全局索引、透明分布式 立即下载
Phoenix 全局索引原理与实践 立即下载