PostgreSQL通过索引获取heap tuple解析

本文涉及的产品
云原生数据库 PolarDB MySQL 版,通用型 2核4GB 50GB
云原生数据库 PolarDB PostgreSQL 版,标准版 2核4GB 50GB
云解析 DNS,旗舰版 1个月
简介: PostgreSQL通过索引获取heap tuple解析

本文介绍通过索引扫描获取heap tuple的TID后,如何通过TID获取heap tuple。

一、先介绍两个数据结构关系

二、接着介绍获取记录流程

1、通过索引扫描后,得到索引记录(key,tid),接着需要通过tid获取对应的heap记录。通过tid获取heap记录的动作由表访问方法接口heapam_index_fetch_tuple函数完成。

2、首先将scan强制转换IndexFetchHeapData类型hscan;slot转换类型BufferHeapTupleTableSlot bslot。

3、call_again初始传进来为false

4、先将hscan->xs_cbuf保存起来,然后调用ReleaseAndReadBuffer读取磁盘页到buffer,该buffer的ID保存到hscan->xs_cbuf

5、页内通过tid获取记录需要在buf描述符content_lock的BUFFER_LOCK_SHARE内进行

6、调用heap_hot_search_buffer在对应buffer内通过tid获取对应heap记录,这里会遇到heap only tuple的情况:

 1)通过tid得到heap的页号及记录索引号。如果进行update过,该tid是第一个打上delete标签的记录,而这个记录的t_ctid会指向新insert的记录。

 2)第一次进来,at_chain_start标记为TRUE即HOT链的起始记录

 3)根据tid解析出的页号和索引号得到记录的索引

 4)第一次进来,并且记录被修剪了,即老记录的索引号指向了最新记录的索引号,此时获取最新记录的索引号,返回3)循环获取其索引并进行判断

 5)记录为最新记录时,获取tuple值并保存到heapTuple中

 6)排除被修剪,第一次进来获取对应tuple后调用HeapTupleSatisfiesVisibility判断可见性,以及隔离性。若可见则返回TRUE,找到记录了;否则第一个记录类型为HOT UPDATED,通过其t_ctid定位到新版本,然后获取并循环开始进行判断

7、找到记录后将tid保持大bslot->base.tupdata.t_self中,然后解锁

8、若找到记录,则将记录保存到slot中,并返回上层。


相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
目录
相关文章
|
1月前
|
数据库 索引
深入探索数据库索引技术:回表与索引下推解析
【10月更文挑战第15天】在数据库查询优化的领域中,回表和索引下推是两个核心概念,它们对于提高查询性能至关重要。本文将详细解释这两个术语,并探讨它们在数据库操作中的作用和影响。
50 3
|
4月前
|
监控 关系型数据库 数据库
PostgreSQL的索引优化策略?
【8月更文挑战第26天】PostgreSQL的索引优化策略?
115 1
|
18小时前
|
SQL 关系型数据库 MySQL
深入解析MySQL的EXPLAIN:指标详解与索引优化
MySQL 中的 `EXPLAIN` 语句用于分析和优化 SQL 查询,帮助你了解查询优化器的执行计划。本文详细介绍了 `EXPLAIN` 输出的各项指标,如 `id`、`select_type`、`table`、`type`、`key` 等,并提供了如何利用这些指标优化索引结构和 SQL 语句的具体方法。通过实战案例,展示了如何通过创建合适索引和调整查询语句来提升查询性能。
21 9
|
2月前
|
SQL 存储 关系型数据库
SQL默认索引是什么:深入解析与技巧
在SQL数据库中,索引是一种用于提高查询性能的重要数据结构
|
4月前
|
存储 数据库 C++
"深入剖析Python元组(tuple):与列表的对比、特性解析及高效应用场景展示"
【8月更文挑战第9天】Python元组与列表虽均用于存储元素集合,但有本质差异。元组不可变,创建后无法修改,适合保护数据不被意外更改的场景,如作字典键或传递固定值。列表则可变,支持动态增删改,适用于需频繁调整的数据集。元组因不可变性而在性能上有优势,可用于快速查找。两者各有千秋,根据具体需求选择使用。例如,元组可用于表示坐标点或日期,而列表更适合管理用户列表或库存。
123 1
|
4月前
|
SQL 存储 数据库
|
4月前
|
存储 SQL 数据库
深入解析SQL中的聚集索引与非聚集索引
【8月更文挑战第31天】
180 0
|
4月前
|
SQL 关系型数据库 MySQL
SQL Server、MySQL、PostgreSQL:主流数据库SQL语法异同比较——深入探讨数据类型、分页查询、表创建与数据插入、函数和索引等关键语法差异,为跨数据库开发提供实用指导
【8月更文挑战第31天】SQL Server、MySQL和PostgreSQL是当今最流行的关系型数据库管理系统,均使用SQL作为查询语言,但在语法和功能实现上存在差异。本文将比较它们在数据类型、分页查询、创建和插入数据以及函数和索引等方面的异同,帮助开发者更好地理解和使用这些数据库。尽管它们共用SQL语言,但每个系统都有独特的语法规则,了解这些差异有助于提升开发效率和项目成功率。
473 0
|
4月前
|
关系型数据库 数据库 PostgreSQL
PostgreSQL索引维护看完这篇就够了
PostgreSQL索引维护看完这篇就够了
316 0
|
5月前
|
SQL 运维 监控
MSSQL性能调优深度解析:索引优化策略、SQL查询优化技巧与高效并发管理实践
在Microsoft SQL Server(MSSQL)的运维与优化领域,性能调优是确保数据库高效运行、满足业务需求的关键环节

推荐镜像

更多