| PostgreSQL 9.0.4 中文文档 | ||||
|---|---|---|---|---|
| Prev | Fast Backward | Chapter 45. 系统表 | Fast Forward | Next |
pg_constraint存储表上的检查约束、主键、唯一约束和外键约束。字段约束不会得到特殊对待。 每个字段约束都等效于某些表约束。非空约束记录在pg_attribute目录中,不是这。
用户定义的约束触发器(创建CREATE CONSTRAINT TRIGGER)也引起本表中的条目。
在域上面的检查约束也存储在这里。
Table 45-12. pg_constraint Columns
| 名称 | 类型 | 引用 | 描述 |
|---|---|---|---|
| conname | name | 约束名(不必是唯一的) | |
| connamespace | oid | pg_namespace.oid | 包含这个约束的名字空间的OID |
| contype | char | c = 检查约束, f = 外键约束, p = 主键约束, u = 唯一约束 t = 约束触发器 x = 排斥约束 | |
| condeferrable | bool | 这个约束可以推迟吗? | |
| condeferred | bool | 缺省时这个约束是否推迟的? | |
| 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 = 限制, c = 级联, n =设置为null, d =设置为缺省 | |
| confdeltype | char | 外键删除动作编码 a = 没动作, r = 限制, c = 级联, n =设置为null, d =设置为缺省 | |
| confmatchtype | char | 外键匹配类型 f = 全部, p = 部分, u = 简单(未指定) | |
| conislocal | bool | 这个约束来定义局部的关系。请注意, 约束可以在本地同时定义和继承。 | |
| coninhcount | int4 | 这个约束有直接继承祖先的数目。不能删除具有约束非零数字的祖先,也不能更名。 | |
| conkey | int2[] | pg_attribute.attnum | 如果一个表约束(包括外键,但没有约束触发器),则是约束控制的字段列表 |
| confkey | int2[] | pg_attribute.attnum | 如果是一个外键,是引用字段的列表 |
| conpfeqop | oid[] | pg_operator.oid | 如果是一个外健,列出相等运算PK = FK 比较的字段列表 |
| conppeqop | oid[] | pg_operator.oid | 如果是一个外健,是相等运算PK = FK 比较的字段列表 |
| conffeqop | oid[] | pg_operator.oid | 如果是一个外健,是相等运算PK = FK 比较的字段列表 |
| conexclop | oid[] | pg_operator.oid | 如果是一个排除约束,是每一列排斥操作符的字段列表 |
| conbin | text | 如果是检查约束,那就是其表达式的内部形式 | |
| consrc | text | 如果是检查约束,则是表达式的人类可读形式 |
在排斥约束的情况下,conkey 是简单列引用的唯一有用约束元素。 对于其他情况下,conkey出现零 和必须查阅发现限制表达的相关索引。 (conkey作为pg_index.indkey 索引有相同的内容)。
Note: 当引用对象改变后,不会更新consrc。例如,它不会跟踪字段名修改。 而不是依赖这个字段,最好还是使用
pg_get_constraintdef()来提取一个检查约束的定义。
Note: pg_class.relchecks需要和在此表上为给定关系找到的检查约束的数目一致。 并且,如果关系中有任何排斥约束记录,pg_class.relhasexclusion必须是真。