pg_constraint

The pg_constraint system catalog table stores check and foreign key 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 table. Check constraints on domains are stored here, too.

Table 1. pg_catalog.pg_constraint

columntypereferencesdescription
connamename Constraint name
connamespaceoidpg_namespace.oidThe OID of the namespace (schema) that contains this constraint.
contypechar c = check constraint, f = foreign key constraint.
condeferrableboolean Is the constraint deferrable?
condeferredboolean Is the constraint deferred by default?
conrelidoidpg_class.oidThe table this constraint is on; 0 if not a table constraint.
contypidoidpg_type.oidThe domain this constraint is on; 0 if not a domain constraint.
confrelidoidpg_class.oidIf a foreign key, the referenced table; else 0.
confupdtypechar Foreign key update action code.
confdeltypechar Foreign key deletion action code.
confmatchtypechar Foreign key match type.
conkeysmallint[]pg_attribute.attnumIf a table constraint, list of columns which the constraint constrains.
confkeysmallint[]pg_attribute.attnumIf a foreign key, list of the referenced columns.
conbintext If a check constraint, an internal representation of the expression.
consrctext If a check constraint, a human-readable representation of the expression. This is not updated when referenced objects change; for example, it won’t track renaming of columns. Rather than relying on this field, it is best to use pg_get_constraintdef() to extract the definition of a check constraint.