48.11. pg_class

В каталоге pg_class описываются таблицы и практически всё, что имеет колонки или каким-то образом подобно таблице. Сюда входят индексы (но смотрите также pg_index), последовательности, представления, материализованные представления, составные типы и таблицы TOAST; см. relkind. Далее, подразумевая все эти типы объектов, мы будем говорить об "отношениях". Не все колонки здесь имеют смысл для всех типов отношений.

Таблица 48-11. Колонки pg_class

ИмяТипСсылкиОписание
oidoid Идентификатор строки (скрытый атрибут; должен выбираться явно)
relnamename Имя таблицы, индекса, представления и т. п.
relnamespaceoidpg_namespace.oidOID пространства имён, содержащего это отношение
reltypeoidpg_type.oidOID типа данных, соответствующего типу строки этой таблицы, если таковой есть (ноль для индексов, так как они не имеют записи в pg_type)
reloftypeoidpg_type.oidДля типизированных таблиц, OID нижележащего составного типа, или ноль для всех других отношений
relowneroidpg_authid.oidВладелец отношения
relamoidpg_am.oidЕсли это индекс, применяемый метод доступа (B-дерево, хеш и т. д.)
relfilenodeoid Имя файла на диске с этим отношением; ноль означает, что это "отображённое" представление, имя файла для которого определяется состоянием на нижнем уровне
reltablespaceoidpg_tablespace.oidТабличное пространство, в котором хранится это отношение. Если ноль, подразумевается пространство базы данных по умолчанию. (Не имеет значения, если с отношением не связан файл на диске.)
relpagesint4 Размер представления этой таблицы на диске (в страницах размера BLCKSZ). Это лишь примерная оценка, используемая планировщиком. Она обновляется командами VACUUM, ANALYZE и несколькими командами DDL, например, CREATE INDEX.
reltuplesfloat4 Число строк в таблице. Это лишь примерная оценка, используемая планировщиком. Она обновляется командами VACUUM, ANALYZE и несколькими командами DDL, например, CREATE INDEX.
relallvisibleint4 Число страниц, помеченных как «полностью видимые» в карте видимости таблицы. Это лишь примерная оценка, используемая планировщиком. Она обновляется командами VACUUM, ANALYZE и несколькими командами DDL, например, CREATE INDEX.
reltoastrelidoidpg_class.oidOID таблицы TOAST, связанной с данной таблицей, или 0, если таковой нет. В таблицу TOAST, как во вторичную, "выносятся" большие атрибуты.
relhasindexbool True, если это таблица и она имеет (или недавно имела) индексы
relissharedbool True, если эта таблица разделяется всеми базами данных в кластере. Разделяемыми являются только некоторые системные каталоги (как например, pg_database).
relpersistencechar p = постоянная таблица (permanent), u = нежурналируемая таблица (unlogged), t = временная таблица (temporary)
relkindchar r = обычная таблица, i = индекс (index), S = последовательность (sequence), v = представление (view), m = материализованное представление (materialized view), c = составной тип (composite), t = таблица TOAST, f = сторонняя таблица (foreign)
relnattsint2 Число пользовательских колонок в отношении (системные колонки не считаются). Столько же соответствующих строк должно быть в pg_attribute. См. также pg_attribute.attnum.
relchecksint2 Число ограничений CHECK в таблице; см. каталог pg_constraint
relhasoidsbool True, если для каждой строки отношения генерируется OID
relhaspkeybool True, если в таблице имеется (или имелся) первичный ключ
relhasrulesbool True, если для таблицы определены (или были определены) правила; см. каталог pg_rewrite
relhastriggersbool True, если для таблицы определены (или были определены) триггеры; см. каталог pg_trigger
relhassubclassbool True, если у таблицы есть (или были) потомки в иерархии наследования
relispopulatedbool True, если отношение наполнено данными (это истинно для всех отношений, кроме некоторых материализованных представлений)
relreplidentchar Колонки, формирующие "идентификатор реплики" для строк: d = по умолчанию (первичный ключ, если есть), n = никакие (nothing), f = все колонки, i = индекс (index), если задано значение indisreplident, либо набор по умолчанию
relfrozenxidxid Идентификаторы транзакций, предшествующие данному, в этой таблице заменены постоянным ("замороженным") идентификатором транзакции. Это нужно для определения, когда требуется очищать таблицу для предотвращения зацикливания идентификаторов или для сокращения объёма pg_clog. Если это отношение — не таблица, значение равно нулю (InvalidTransactionId).
relminmxidxid Идентификаторы мультитранзакций, предшествующие данному, в этой таблице заменены другим идентификатором транзакции. Это нужно для определения, когда требуется очищать таблицу для предотвращения зацикливания идентификаторов мультитранзакций или для сокращения объёма pg_multixact. Если это отношение — не таблица, значение равно нулю (InvalidMultiXactId).
relaclaclitem[] Права доступа; за подробностями обратитесь к описанию GRANT и REVOKE
reloptionstext[] Специальные параметры для методов доступа, в виде строк "ключ=значение"

Некоторые логические флаги в pg_class поддерживаются не строго: гарантируется, что они будут установлены при переходе в определённое состояние, но они могут не сбрасываться немедленно, когда условия поменяются. Например, relhasindex устанавливается командой CREATE INDEX, но никогда не сбрасывается командой DROP INDEX. Вместо этого, флаг relhasindex сбрасывается командой VACUUM, если она находит, что в таблице нет индексов. Такая организация позволяет избежать состояния гонки и способствует параллельному использованию.