更新时间:2024-06-03 GMT+08:00

PG_INDEX

PG_INDEX系统表存储索引的一部分信息,其他的信息大多数在PG_CLASS中。

表1 PG_INDEX字段

名称

类型

描述

indexrelid

oid

这个索引在12.2.15.28 PG_CLASS里的记录的OID。

indrelid

oid

使用这个索引的表在12.2.15.28 PG_CLASS里的记录的OID。

indnatts

smallint

索引中的字段数目。

indisunique

boolean

是否为唯一索引。

  • true:是唯一索引。
  • false:不是唯一索引。

indisprimary

boolean

该索引是否为该表的主键。

  • true:该索引是该表的主键。这个字段为真的时候indisunique总是为真。
  • false:该索引不是该表的主键。

indisexclusion

boolean

该索引是否支持排他约束。

  • true:该索引支持排他约束。
  • false:该索引不支持排他约束。

indimmediate

boolean

插入数据时是否进行唯一性检查。

  • true:在插入数据时会立即进行唯一性检查。
  • false:在插入数据时不会进行唯一性检查。

indisclustered

boolean

该表是否在这个索引上建簇。

  • true:该表在这个索引上建簇。
  • false:该表没有在这个索引上建簇。

indisusable

boolean

该索引对insert/select是否可用。

  • true:该索引对insert/select可用。
  • false:该索引对insert/select不可用。

indisvalid

boolean

  • true:该索引可以用于查询。
  • false:该索引可能不完整,仍然必须在INSERT/UPDATE操作时进行更新,不过不能安全的用于查询。如果是唯一索引,则唯一属性也将不为真。

indcheckxmin

boolean

  • true:查询不能使用索引,直到pg_index此行的xmin低于其快照的TransactionXmin,因为该表可能包含它们能看到的不兼容行断开的HOT链。
  • false:查询可以用索引。

indisready

boolean

  • true:此索引对插入数据是可用的。
  • false:在插入或修改数据时忽略此索引。

indkey

int2vector

这是一个包含indnatts值的数组,这些数组值表示这个索引所建立的表字段。比如一个值为1 3的意思是第一个字段和第三个字段组成这个索引键字。这个数组里的零表明对应的索引属性是在这个表字段上的一个表达式,而不是一个简单的字段引用。

indcollation

oidvector

索引各列对应的排序规则的OID,详情请参考PG_COLLATION

indclass

oidvector

对于索引键字里面的每个字段,这个字段都包含一个指向所使用的操作符类的OID,详情请参考12.2.15.53 PG_OPCLASS

indoption

int2vector

存储列前标识位,该标识位是由索引的访问方法定义。

indexprs

pg_node_tree

表达式树(以nodeToString()形式表现)用于那些非简单字段引用的索引属性。它是一个列表,个数与indkey中的零值个数相同。如果所有索引属性都是简单的引用,则为空。

indpred

pg_node_tree

部分索引断言的表达式树(以nodeToString()的形式表现)。如果不是部分索引,则是空字符串。

indisreplident

boolean

此索引的列是否为逻辑解码的解码列。

  • true:此索引的列成为逻辑解码的解码列。
  • false:此索引的列不是逻辑解码的解码列。

indnkeyatts

smallint

索引中的总字段数,超出indnatts的部分不参与索引查询。

indcctmpid

oid

Ustore在线创建索引时临时表OID。

indisvisible

boolean

  • true:此索引状态为可见,即优化器可以使用此索引。
  • false:此索引状态为不可见,此时若enable_invisible_indexes参数为off,则优化器不可以使用此索引;若enable_invisible_indexes参数为on,则优化器可以使用此索引。