前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >PostgreSQL的heapgetpage函数解析

PostgreSQL的heapgetpage函数解析

作者头像
yzsDBA
发布2020-10-28 10:03:58
7460
发布2020-10-28 10:03:58
举报
文章被收录于专栏:PostgreSQL研究与原理解析

本文介绍heapgetpage函数的流程,这个函数的功能是从磁盘中读取一个页到内存,并将可见的记录的记录号,即第几个记录,保存到扫描描述符的rs_vistuples数组中。

1、heapgetpage的入参分别为表扫描描述符和页号,此页号为物理文件中的页号

2、首先将表扫描描述符转换类型heap扫描描述符

3、调用函数ReadBufferExtended从磁盘中读取page号的页到内存:block号为scan->rs_cbuf的内存块中

4、保存下来但扫描的数据页页号scan->rs_cblock=page

5、对该buffer描述符BufferDesc的content_lock加BUFFER_LOCK_SHARE锁

6、计算该页内总共有多少记录,包括死记录,个数为lines

7、如果该页的pd_flags字段存有PD_ALL_VISIBLE,即该页所有记录都可见,则all_visible为TRUE,需要将所有记录都放到scan->rs_vistuples数组中。

8、从第一个记录开始遍历,一直到最后一个记录:正常记录的话,若页内没有PD_ALL_VISIBLE标签,则需要判断该记录可见性,若可见则将其保存到scan->rs_vistuples数组中。

9、记录在heap中是第i个,则scan->rs_vistuples数组保存的是i值

10、对该buffer描述符BufferDesc的content_lock解锁

11、scan->rs_ntuple为可见记录的个数

12、此时heap扫描描述符的成员变量获得值:

scan->rs_cbuf:当前扫描的内存块块号

scan->rs_cblock:当前扫描的文件中页号

scan->rs_vistuples[]:保存可见记录的索引号

scan->rs_ntuples:该页中有多少可见记录

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-02-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 yanzongshuaiDBA 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档