PG_PARTITION

PG_PARTITION系统表存储数据库内所有分区表(partitioned table)、分区(table partition)、分区上toast表和分区索引(index partition)四类对象的信息。分区表索引(partitioned index)的信息不在PG_PARTITION系统表中保存。

表 1 PG_PARTITION字段

名称

类型

描述

oid

oid

行标识符(隐含属性,必须明确选择)。

relname

name

分区表、分区、分区上toast表和分区索引的名称。

parttype

“char”

对象类型:
  • ‘r’:partitioned table
  • ‘p’:table partition
  • ‘s’:table subpartition
  • ‘x’:index partition
  • ‘t’:toast table

parentid

oid

当对象为分区表或分区时,此字段表示分区表在PG_CLASS中的OID。

当对象为index partition时,此字段表示所属分区表索引(partitioned index)的OID。

rangenum

integer

保留字段。

intervalnum

integer

保留字段。

partstrategy

“char”

分区表分区策略,现在仅支持:
  • ‘r’:范围分区。
  • ‘v’:数值分区。
  • ‘i’:间隔分区。
  • ‘l’:list分区。
  • ‘h’:hash分区。
  • ‘n’:无效分区。

relfilenode

oid

table partition、index partition、分区上toast表的物理存储位置。

reltablespace

oid

table partition、index partition、分区上toast表所属表空间的OID。

relpages

double precision

统计信息:table partition、index partition的数据页数量。

reltuples

double precision

统计信息:table partition、index partition的元组数。

relallvisible

integer

统计信息:table partition、index partition的可见数据页数。

reltoastrelid

oid

table partition所对应toast表的OID。

reltoastidxid

oid

table partition所对应toast表的索引的OID。

indextblid

oid

index partition对应table partition的OID。

indisusable

boolean

分区索引是否可用。

reldeltarelid

oid

Delta表的OID。

reldeltaidx

oid

Delta表的索引表的OID。

relcudescrelid

oid

CU描述表的OID。

relcudescidx

oid

CU描述表的索引表的OID。

relfrozenxid

xid32

冻结事务ID号。

为保持前向兼容,保留此字段,新增relfrozenxid64用于记录此信息。

intspnum

integer

间隔分区所属表空间的个数。

partkey

int2vector

分区键的列号。

intervaltablespace

oidvector

间隔分区所属的表空间,间隔分区以round-robin方式落在这些表空间内。

interval

text[]

间隔分区的间隔值。

boundaries

text[]

范围分区和间隔分区的上边界。

transit

text[]

间隔分区的跳转点。

reloptions

text[]

设置partition的存储属性,与pg_class.reloptions的形态一样,用“keyword=value”格式的字符串来表示 ,目前用于在线扩容的信息搜集。

relfrozenxid64

xid

冻结事务ID号。

relminmxid

xid

冻结多事务ID号。

partitionno

integer

用于维护分区表中的分区Map结构。
  • 当对象为分区时,此字段表示分区ID,从1开始自增。
  • 当对象为分区表时,此字段表示分区ID的最大值,并使用负值来特殊标记,该值会随着部分分区DDL语法不断递增。
  • 当对象为其他类型时,此字段为空值,没有任何含义。

partitionno是一个永久自增列,可以通过语法ALTER TABLE t_name RESET PARTITION或者VACUUM FULL命令重置/回收。

subpartitionno

integer

用于维护分区表中的二级分区Map结构。
  • 当对象为二级分区时,此字段表示二级分区ID,从1开始自增。
  • 当对象为二级分区表的一级分区时,此字段表示二级分区ID的最大值,并使用负值来特殊标记,该值会随着部分分区DDL语法不断递增。
  • 当对象为其他类型时,此字段为空值,没有任何含义。

subpartitionno是一个永久自增列,可以通过语法ALTER TABLE t_name RESET PARTITION或者VACUUM FULL命令重置/回收。