42.13. pg_constraint

系统表 pg_constraint 存储表上的检查约束、主键、唯一约束和外键约束。 (字段约束不会得到特殊对待。每个字段约束都等效于某些表约束。) 参阅 CREATE TABLE 获取更多信息。

在域上面的检查约束存储在这里。

Table 42-13. pg_constraint 字段

名字类型引用描述
connamename 约束名字(不一定是唯一的!)
connamespaceoidpg_namespace.oid 包含这个约束的名字空间的 OID
contypechar  c = 检查约束, f = 外键约束, p = 主键约束, u = 唯一约束
condeferrableboolean 这个约束可以推迟吗?
condeferredboolean 缺省时这个约束是否推迟的?
conrelidoidpg_class.oid这个约束所在的表;如果不是表约束则为 0
contypidoidpg_type.oid这个约束所在的域;如果不是一个域约束则为 0
confrelidoidpg_class.oid如果是外键,则为参考的表;否则为 0
confupdtypechar 外键更新动作代码
confdeltypechar 外键删除动作代码
confmatchtypechar 外键匹配类型
conkeyint2[]pg_attribute.attnum如果是表约束,则是约束控制的字段列表
confkeyint2[]pg_attribute.attnum如果是一个外键,是参考的字段的列表
conbintext 如果是检查约束,那就是其表达式的内部形式
consrctext 如果是检查约束,则是表达式的人类可读形式

注意: consrc 在被引用的对象改变之后不会被更新, 它不会跟踪字段的名字修改。与其依赖这个字段,我们最好还是使用 pg_get_constraintdef() 来抽取一个检查约束的定义。

注意: pg_class.relchecks 需要和在此表上为给定关系找到的检查约束的数目一致。