53.13. pg_constraint
#
В каталоге pg_constraint
хранятся ограничения-проверки, ограничения-исключения, а также ограничения первичного ключа, уникальности и внешних ключей, определённые для таблиц. (Ограничения столбцов описываются как и все остальные. Любое ограничение столбца равнозначно некоторому ограничению таблицы.) Ограничения на NULL представляются не здесь, а в каталоге pg_attribute
.
Для пользовательских триггеров ограничений (создаваемых командой CREATE CONSTRAINT TRIGGER
) в этой таблице также создаётся запись.
Здесь также хранятся ограничения доменов.
Таблица 53.13. Столбцы pg_constraint
Тип столбца Описание |
---|
Идентификатор строки |
Имя ограничения (не обязательно уникальное!) |
OID пространства имён, содержащего это ограничение |
|
Является ли ограничение откладываемым? |
Является ли ограничение отложенным по умолчанию? |
Было ли ограничение проверено? В настоящее время значение false возможно только для внешних ключей и ограничений CHECK |
Таблица, для которой установлено это ограничение; ноль, если это не ограничение таблицы |
Домен, к которому относится это ограничение; ноль, если это не ограничение домена |
Индекс, поддерживающий это ограничение, если это ограничение уникальности, первичного или внешнего ключа, либо ограничение-исключение; в противном случае — ноль |
Соответствующее ограничение в родительской секционированной таблице, если это ограничение в секции; иначе ноль |
Если это внешний ключ, таблица, на которую он ссылается; иначе ноль |
Код действия при изменении внешнего ключа: |
Код действия при удалении внешнего ключа: |
Тип сопоставления внешнего ключа: |
Ограничение определено локально в данном отношении. Заметьте, что ограничение может быть определено локально и при этом наследоваться. |
Число прямых предков этого ограничения. Ограничение с ненулевым числом предков нельзя удалить или переименовать. |
Ограничение определено локально для данного отношения и является ненаследуемым. |
Для ограничений таблицы (включая внешние ключи, но не триггеры ограничений), определяет список столбцов, образующих ограничение |
Для внешнего ключа определяет список столбцов, на которые он ссылается |
Для внешнего ключа — список операторов равенства для сравнений PK = FK |
Для внешнего ключа — список операторов равенства для сравнений PK = PK |
Для внешнего ключа — список операторов равенства для сравнений FK = FK |
Для внешнего ключа с указанием |
Для ограничения-исключения — список операторов исключения по столбцам |
Для ограничения-проверки — внутреннее представление выражения. (Чтобы извлечь определение ограничения-проверки, рекомендуется использовать |
В случае с ограничением-исключением значение conkey
полезно только для элементов ограничений, представляющих простые ссылки на столбцы. Для других случаев в conkey
задаётся ноль, и чтобы получить выражение, определяющее ограничение, надо обратиться к соответствующему индексу. (Таким образом, поле conkey
имеет то же содержимое, что и pg_index
.indkey
для индекса.)
Примечание
Поле pg_class.relchecks
должно согласовываться с числом ограничений-проверок, описанных в данной таблице для каждого отношения.
53.13. pg_constraint
#
The catalog pg_constraint
stores check, primary key, unique, foreign key, and exclusion constraints on tables. (Column constraints are not treated specially. Every column constraint is equivalent to some table constraint.) Not-null constraints are represented in the pg_attribute
catalog, not here.
User-defined constraint triggers (created with CREATE CONSTRAINT TRIGGER
) also give rise to an entry in this table.
Check constraints on domains are stored here, too.
Table 53.13. pg_constraint
Columns
Column Type Description |
---|
Row identifier |
Constraint name (not necessarily unique!) |
The OID of the namespace that contains this constraint |
|
Is the constraint deferrable? |
Is the constraint deferred by default? |
Has the constraint been validated? Currently, can be false only for foreign keys and CHECK constraints |
The table this constraint is on; zero if not a table constraint |
The domain this constraint is on; zero if not a domain constraint |
The index supporting this constraint, if it's a unique, primary key, foreign key, or exclusion constraint; else zero |
The corresponding constraint of the parent partitioned table, if this is a constraint on a partition; else zero |
If a foreign key, the referenced table; else zero |
Foreign key update action code: |
Foreign key deletion action code: |
Foreign key match type: |
This constraint is defined locally for the relation. Note that a constraint can be locally defined and inherited simultaneously. |
The number of direct inheritance ancestors this constraint has. A constraint with a nonzero number of ancestors cannot be dropped nor renamed. |
This constraint is defined locally for the relation. It is a non-inheritable constraint. |
If a table constraint (including foreign keys, but not constraint triggers), list of the constrained columns |
If a foreign key, list of the referenced columns |
If a foreign key, list of the equality operators for PK = FK comparisons |
If a foreign key, list of the equality operators for PK = PK comparisons |
If a foreign key, list of the equality operators for FK = FK comparisons |
If a foreign key with a |
If an exclusion constraint, list of the per-column exclusion operators |
If a check constraint, an internal representation of the expression. (It's recommended to use |
In the case of an exclusion constraint, conkey
is only useful for constraint elements that are simple column references. For other cases, a zero appears in conkey
and the associated index must be consulted to discover the expression that is constrained. (conkey
thus has the same contents as pg_index
.indkey
for the index.)
Note
pg_class.relchecks
needs to agree with the number of check-constraint entries found in this table for each relation.