PostgreSQL的heapgetpage函数解析

本文介绍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:该页中有多少可见记录

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yzs87

你的鼓励是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值