pg_constraint   目录pg_constraint存储表上的检查、主键、唯一、外键和排他约束(列约束也不会被特殊对待。每一个列约束都等同于某种表约束。)。非空约束不在这里,而是在pg_attribute目录中表示。
  
   用户定义的约束触发器(使用CREATE CONSTRAINT
   TRIGGER创建)也会在这个表中产生一项。
  
域上的检查约束也存储在这里。
表 51.13. pg_constraint的列
| 名称 | 类型 | 引用 | 描述 | 
|---|---|---|---|
| oid | oid | 行标识符(隐藏属性,必须被显式选择才会显示) | |
| conname | name | 约束名字(不需要唯一!) | |
| connamespace | oid |  | 包含此约束的名字空间的OID | 
| contype | char | c= 检查约束,f= 外键约束,p= 主键约束,u= 唯一约束,t= 约束触发器,x= 排他约束 | |
| condeferrable | bool | 该约束是否能被延迟? | |
| condeferred | bool | 该约束是否默认被延迟? | |
| convalidated | bool | 此约束是否被验证过?当前对于外键和检查约束只能是假 | |
| conrelid | oid |  | 该约束所在的表,如果不是表约束则为0 | 
| contypid | oid |  | 该约束所在的域,如果不是域约束则为0 | 
| conindid | oid |  | 如果该约束是唯一、主键、外键或排他约束,此列表示支持此约束的索引,否则为0 | 
| confrelid | oid |  | 如果此约束是一个外键约束,此列为被引用的表,否则为0 | 
| confupdtype | char | 外键更新动作代码: a= 无动作,r= 限制,c= 级联,n= 置空,d= 置为默认值 | |
| confdeltype | char | 外键删除动作代码: a= 无动作,r= 限制,c= 级联,n= 置空,d= 置为默认值 | |
| confmatchtype | char | 外键匹配类型: f= 完全,p= 部分,s= 简单 | |
| 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为0且必须查阅相关索引来发现被约束的表达式(conkey因此和pg_index.indkey具有相同的内容)。
  
    当被引用对象改变时,consrc不能被更新。例如,它不跟踪列的重命名。最好使用pg_get_constraintdef()来抽取一个检查约束的定义,而不是依赖这个域。
   
    pg_class.relchecks需要和每个关系在此目录中的检查约束数量保持一致。