您的位置:58脚本 > PostgreSQL 索引访问方法接口定义

PostgreSQL 索引访问方法接口定义

2023-05-24 10:32

 PostgreSQL 索引访问方法接口定义

目录

61.1. 索引的基本 API 结构
61.2. 索引访问方法函数
61.3. 索引扫描
61.4. 索引锁定考虑
61.5. 索引唯一性检查
61.6. 索引开销估计函数

本章定义核心PostgreSQL系统和管理个别索引类型的索引访问方法之间的接口。除 了在这里指定的内容之外,核心系统对索引一无所知,因此可以通过编写附加代码来开发全新的索引类型。

PostgreSQL中所有的索引在技术上都叫做二级索引。也就是说,索引在物理上与它描述的表文件分离。每个索引被存储为它自己的物理关系并且被pg_class目录中的一个项所描述。一个索引的内容完全受到其索引访问方法控制。实际上,所有索引访问方法都把索引划分成标准大小的页面, 这样它们就可以使用常规的存储管理器和缓冲区管理器来访问索引内容(所有现有的索引访问方法还使用第 68.6 节中描述的标准页面布局,并且大部分都使用相同的索引元组头部格式;但是这些决定都不是强制在访问方法上的)。

索引实际上是一些数据键值与索引父表中行版本(元组)的元组标识符或TIDs之间的映射。一个 TID 由一个块号和一个块内的项编号组成(见第 68.6 节)。 这对于从表中取一个特定行就足够了。索引并不直接知道在 MVCC下,同一个逻辑行可能有多个现存的版本;对于索引而言,每个 行都是一个独立的对象,都需要自己的索引项。因此,对一行的更新总是为该行创建全新的索引项,即使键值没有改变(HOT 元组对这段陈述来说是个异常,但是索引也不会处理这些)。死亡元组的索引项将在随着死亡元组的回收而被回收(通过清理)。


阅读全文
以上是58脚本为你收集整理的 PostgreSQL 索引访问方法接口定义全部内容。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
相关文章
© 2024 58脚本 58jiaoben.com 版权所有 联系我们
桂ICP备12005667号-28 Powered by CMS