受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

65.4. 可见性映射 #

每个堆关系都有一个可见性映射(VM),用于跟踪哪些页面只包含已知对所有活动事务都可见的 元组;它还会跟踪哪些页面只包含已冻结的元组。它与主关系数据并列存放在一个独立的关系分支中, 名称由关系的 filenode 编号加上 _vm 后缀构成。例如,如果某关系的 filenode 是 12345,那么 VM 会存储在名为 12345_vm 的文件中, 与主关系文件位于同一目录。请注意,索引没有 VM。

可见性映射为每个堆页面存储两个位。第一位若被置位,表示该页面是全部可见(all-visible), 换句话说,该页面不包含任何需要被清理的元组。这些信息还可以被 仅索引扫描 用来只依据索引元组回答查询。第二位若被置位,则表示页面上的所有元组都已经被冻结。 这意味着,即使是防回卷清理也不必重新访问该页面。

这个映射是保守的,也就是说,只要某个位被置位,我们就能确定相应条件确实成立; 但如果某个位没有置位,该条件既可能为真,也可能不为真。可见性映射位只会由 VACUUM 设置,但页面上的任何数据修改操作都会把它们清除。

pg_visibility 模块可用于检查可见性映射中存储的信息。

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。