50.13. pg_constraint
В каталоге pg_constraint хранятся ограничения-проверки, ограничения-исключения, а также ограничения первичного ключа, уникальности и внешних ключей, определённые для таблиц. (Ограничения столбцов описываются как и все остальные. Любое ограничение столбца равнозначно некоторому ограничению таблицы.) Ограничения на NULL представляются не здесь, а в каталоге pg_attribute.
Для пользовательских триггеров ограничений (создаваемых командой CREATE CONSTRAINT TRIGGER) в этой таблице также создаётся запись.
Здесь также хранятся ограничения доменов.
Таблица 50.13. Столбцы pg_constraint
| Имя | Тип | Ссылки | Описание | 
|---|---|---|---|
| oid | oid | Идентификатор строки (скрытый атрибут; должен выбираться явно) | |
| conname | name | Имя ограничения (не обязательно уникальное!) | |
| connamespace | oid |  | OID пространства имён, содержащего это ограничение | 
| contype | char | c= ограничение-проверка (check),f= внешний ключ (foreign key),p= первичный ключ (primary key),u= ограничение уникальности (unique),t= триггер ограничения (trigger),x= ограничение-исключение (exclusion) | |
| condeferrable | bool | Является ли ограничение откладываемым? | |
| condeferred | bool | Является ли ограничение отложенным по умолчанию? | |
| convalidated | bool | Было ли ограничение проверено? В настоящее время значение false возможно только для внешних ключей и ограничений CHECK | |
| conrelid | oid |  | Таблица, для которой установлено это ограничение; 0, если это не ограничение таблицы | 
| contypid | oid |  | Домен, к которому относится это ограничение; 0, если это не ограничение домена | 
| conindid | oid |  | Индекс, поддерживающий это ограничение, если это ограничение уникальности, первичного или внешнего ключа, либо ограничение-исключение; в противном случае — 0 | 
| confrelid | oid |  | Если это внешний ключ, таблица, на которую он ссылается; иначе 0 | 
| confupdtype | char | Код действия при изменении внешнего ключа: a= нет действия,r= ограничить (restrict),c= каскадное действие (cascade),n= присвоить NULL,d= поведение по умолчанию | |
| confdeltype | char | Код действия при удалении внешнего ключа: a= нет действия,r= ограничить (restrict),c= каскадное действие (cascade),n= присвоить NULL,d= поведение по умолчанию | |
| confmatchtype | char | Тип сопоставления внешнего ключа: f= полное (full),p= частичное (partial),s= простое (simple) | |
| conislocal | bool | Ограничение определено локально в данном отношении. Заметьте, что ограничение может быть определено локально и при этом наследоваться. | |
| coninhcount | int4 | Число прямых предков этого ограничения. Ограничение с ненулевым числом предков нельзя удалить или переименовать. | |
| connoinherit | bool | Ограничение определено локально для данного отношения и является ненаследуемым. | |
| conkey | int2[] |  | Для ограничений таблицы (включая внешние ключи, но не триггеры ограничений), определяет список столбцов, образующих ограничение | 
| confkey | int2[] |  | Для внешнего ключа определяет список столбцов, на которые он ссылается | 
| conpfeqop | oid[] |  | Для внешнего ключа — список операторов равенства для сравнений PK = FK | 
| conppeqop | oid[] |  | Для внешнего ключа — список операторов равенства для сравнений PK = PK | 
| conffeqop | oid[] |  | Для внешнего ключа — список операторов равенства для сравнений FK = FK | 
| conexclop | oid[] |  | Для ограничения-исключения — список операторов исключения по столбцам | 
| conbin | pg_node_tree | Для ограничения-проверки — внутреннее представление выражения | |
| consrc | text | Для ограничения-проверки — понятное человеку представление выражения | 
В случае с ограничением-исключением значение conkey полезно только для элементов ограничений, представляющих простые ссылки на столбцы. Для других случаев в conkey задаётся ноль, и чтобы получить выражение, определяющее ограничение, надо обратиться к соответствующему индексу. (Таким образом, поле conkey имеет то же содержимое, что и pg_index.indkey для индекса.)
Примечание
Поле consrc не меняется при изменении задействованных в выражении объектов; например, в нём не отслеживается переименование столбцов. Поэтому лучше не полагаться на него, а воспользоваться функцией pg_get_constraintdef(), чтобы получить определение ограничения-проверки.
Примечание
Поле pg_class.relchecks должно согласовываться с числом ограничений-проверок, описанных в данной таблице для каждого отношения.