52.13. pg_constraint #
В каталоге pg_constraint хранятся ограничения-проверки, ограничения-исключения, ограничения NOT NULL, а также ограничения первичного ключа, уникальности и внешних ключей, определённые для таблиц. (Ограничения столбцов описываются как и все остальные. Любое ограничение столбца равнозначно некоторому ограничению таблицы.)
Для пользовательских триггеров ограничений (создаваемых командой CREATE CONSTRAINT TRIGGER) в этой таблице также создаётся запись.
Здесь также хранятся ограничения доменов.
Таблица 52.13. Столбцы pg_constraint
Тип столбца Описание  | 
|---|
 Идентификатор строки  | 
 Имя ограничения (не обязательно уникальное!)  | 
 OID пространства имён, содержащего это ограничение  | 
 
  | 
 Является ли ограничение откладываемым?  | 
 Является ли ограничение отложенным по умолчанию?  | 
 Действует ли ограничение?  | 
 Ограничение проверено?  | 
 Таблица, для которой установлено это ограничение; ноль, если это не ограничение таблицы  | 
 Домен, к которому относится это ограничение; ноль, если это не ограничение домена  | 
 Индекс, поддерживающий это ограничение, если это ограничение уникальности, первичного или внешнего ключа, либо ограничение-исключение; в противном случае — ноль  | 
 Соответствующее ограничение в родительской секционированной таблице, если это ограничение в секции; иначе ноль  | 
 Если это внешний ключ, таблица, на которую он ссылается; иначе ноль  | 
 Код действия при изменении внешнего ключа:   | 
 Код действия при удалении внешнего ключа:   | 
 Тип сопоставления внешнего ключа:   | 
 Ограничение определено локально в данном отношении. Заметьте, что ограничение может быть определено локально и при этом наследоваться.  | 
 Число прямых предков этого ограничения. Ограничение с ненулевым числом предков нельзя удалить или переименовать.  | 
 Ограничение определено локально для данного отношения и является ненаследуемым.  | 
 Это ограничение определено с помощью   | 
 Для ограничений таблицы (включая внешние ключи, но не триггеры ограничений), определяет список столбцов, образующих ограничение  | 
 Для внешнего ключа определяет список столбцов, на которые он ссылается  | 
 Для внешнего ключа — список операторов равенства для сравнений PK = FK  | 
 Для внешнего ключа — список операторов равенства для сравнений PK = PK  | 
 Для внешнего ключа — список операторов равенства для сравнений FK = FK  | 
 Для внешнего ключа с указанием   | 
 Для ограничения-исключения или ограничения первичного ключа/уникальности   | 
 Для ограничения-проверки — внутреннее представление выражения. (Чтобы извлечь определение ограничения-проверки, рекомендуется использовать   | 
В случае с ограничением-исключением значение conkey полезно только для элементов ограничений, представляющих простые ссылки на столбцы. Для других случаев в conkey задаётся ноль, и чтобы получить выражение, определяющее ограничение, надо обратиться к соответствующему индексу. (Таким образом, поле conkey имеет то же содержимое, что и pg_index.indkey для индекса.)
Примечание
Поле pg_class.relchecks должно согласовываться с числом ограничений-проверок, описанных в данной таблице для каждого отношения.