Документация по PostgreSQL 9.4.1 | |||
---|---|---|---|
Пред. | Уровень выше | Глава 48. Системные каталоги | След. |
48.13. pg_constraint
В каталоге pg_constraint хранятся ограничения-проверки, ограничения-исключения, а также ограничения первичного ключа, уникальности и внешних ключей, определённые для таблиц. (Ограничения колонок описываются как и все остальные. Любое ограничение колонки равнозначно некоторому ограничению таблицы.) Ограничения на NULL представляются не здесь, а в каталоге pg_attribute.
Для пользовательских триггеров ограничений (создаваемых командой CREATE CONSTRAINT TRIGGER) в этой таблице также создаётся запись.
Здесь также хранятся ограничения доменов.
Таблица 48-13. Колонки pg_constraint
Имя | Тип | Ссылки | Описание |
---|---|---|---|
oid | oid | Идентификатор строки (скрытый атрибут; должен выбираться явно) | |
conname | name | Имя ограничения (не обязательно уникальное!) | |
connamespace | oid | pg_namespace.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 | pg_class.oid | Таблица, для которой установлено это ограничение; 0, если это не ограничение таблицы |
contypid | oid | pg_type.oid | Домен, к которому относится это ограничение; 0, если это не ограничение домена |
conindid | oid | pg_class.oid | Индекс, поддерживающий это ограничение, если это ограничение уникальности, первичного или внешнего ключа, либо ограничение-исключение; в противном случае — 0 |
confrelid | oid | pg_class.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[] | pg_attribute.attnum | Для ограничений таблицы (включая внешние ключи, но не триггеры ограничений), определяет список колонок, образующих ограничение |
confkey | int2[] | pg_attribute.attnum | Для внешнего ключа определяет список колонок, на которые он ссылается |
conpfeqop | oid[] | pg_operator.oid | Для внешнего ключа список операторов равенства для сравнений PK = FK |
conppeqop | oid[] | pg_operator.oid | Для внешнего ключа список операторов равенства для сравнений PK = PK |
conffeqop | oid[] | pg_operator.oid | Для внешнего ключа список операторов равенства для сравнений FK = FK |
conexclop | oid[] | pg_operator.oid | Для ограничения-исключения список операторов исключения по колонкам |
conbin | pg_node_tree | Для ограничения-проверки внутреннее представление выражения | |
consrc | text | Для ограничения-проверки понятное человеку представление выражения |
В случае с ограничением-исключением значение conkey полезно только для элементов ограничений, представляющих простые ссылки на колонки. Для других случаев в conkey задаётся ноль, и чтобы получить выражение, определяющее ограничение, надо обратиться к соответствующему индексу. (Таким образом, поле conkey имеет то же содержимое, что и pg_index.indkey для индекса.)
Замечание: Поле consrc не меняется при изменении задействованных в выражении объектов; например, в нём не отслеживается переименование колонок. Поэтому лучше не полагаться на него, а воспользоваться функцией
pg_get_constraintdef()
, чтобы получить определение ограничения-проверки.
Замечание: Поле pg_class.relchecks должно согласовываться с числом ограничений-проверок, описанных в данной таблице для каждого отношения.
Пред. | Начало | След. |
pg_collation | Уровень выше | pg_conversion |