50.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 50.13. pg_constraint Columns
| Name | Type | References | Description | 
|---|---|---|---|
| oid | oid | Row identifier (hidden attribute; must be explicitly selected) | |
| conname | name | Constraint name (not necessarily unique!) | |
| connamespace | oid |  | The OID of the namespace that contains this constraint | 
| contype | char | c= check constraint,f= foreign key constraint,p= primary key constraint,u= unique constraint,t= constraint trigger,x= exclusion constraint | |
| condeferrable | bool | Is the constraint deferrable? | |
| condeferred | bool | Is the constraint deferred by default? | |
| convalidated | bool | Has the constraint been validated? Currently, can only be false for foreign keys and CHECK constraints | |
| conrelid | oid |  | The table this constraint is on; 0 if not a table constraint | 
| contypid | oid |  | The domain this constraint is on; 0 if not a domain constraint | 
| conindid | oid |  | The index supporting this constraint, if it's a unique, primary key, foreign key, or exclusion constraint; else 0 | 
| conparentid | oid |  | The corresponding constraint in the parent partitioned table, if this is a constraint in a partition; else 0 | 
| confrelid | oid |  | If a foreign key, the referenced table; else 0 | 
| confupdtype | char | Foreign key update action code: a= no action,r= restrict,c= cascade,n= set null,d= set default | |
| confdeltype | char | Foreign key deletion action code: a= no action,r= restrict,c= cascade,n= set null,d= set default | |
| confmatchtype | char | Foreign key match type: f= full,p= partial,s= simple | |
| conislocal | bool | This constraint is defined locally for the relation. Note that a constraint can be locally defined and inherited simultaneously. | |
| coninhcount | int4 | The number of direct inheritance ancestors this constraint has. A constraint with a nonzero number of ancestors cannot be dropped nor renamed. | |
| connoinherit | bool | This constraint is defined locally for the relation. It is a non-inheritable constraint. | |
| conkey | int2[] |  | If a table constraint (including foreign keys, but not constraint triggers), list of the constrained columns | 
| confkey | int2[] |  | If a foreign key, list of the referenced columns | 
| conpfeqop | oid[] |  | If a foreign key, list of the equality operators for PK = FK comparisons | 
| conppeqop | oid[] |  | If a foreign key, list of the equality operators for PK = PK comparisons | 
| conffeqop | oid[] |  | If a foreign key, list of the equality operators for FK = FK comparisons | 
| conexclop | oid[] |  | If an exclusion constraint, list of the per-column exclusion operators | 
| conbin | pg_node_tree | If a check constraint, an internal representation of the expression | |
| consrc | text | If a check constraint, a human-readable representation of the expression | 
 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
consrc is not updated when referenced objects change; for example, it won't track renaming of columns. Rather than relying on this field, it's best to use pg_get_constraintdef() to extract the definition of a check constraint. 
Note
pg_class.relchecks needs to agree with the number of check-constraint entries found in this table for each relation.