这个系统表存储表上的 CHECK,PRIMARY KEY,UNIQUE,和 FOREIGN KEY 约束。(字段约束不会得到特殊对待。每个字段约束都等效于某些表约束。) 参阅 CREATE TABLE 获取更多信息。
注意: NOT NULL 约束在 pg_attribute 表中表现。
在域上面的 CHECK 约束存储在这里。全局断言(Global ASSERTIONS) (一种目前还不支持的 SQL 特性)将来的某一天也可能出现在这里。
Table 3-10. pg_constraint 字段
| 名字 | 类型 | 引用 | 描述 |
|---|---|---|---|
| conname | name | 约束名字(不一定是唯一的!) | |
| connamespace | oid | pg_namespace.oid | 包含这个约束的名字空间的 OID |
| contype | char | 'c' = 检查约束, 'f' = 外键约束, 'p' = 主键约束, 'u' = 唯一约束 | |
| condeferrable | boolean | 这个约束可以推迟吗? | |
| condeferred | boolean | 缺省时这个约束是否推迟的? | |
| conrelid | oid | pg_class.oid | 这个约束所在的表;如果不是表约束则为 0 |
| contypid | oid | pg_type.oid | 这个约束所在的域;如果不是一个域约束则为 0 |
| confrelid | oid | pg_class.oid | 如果是外键,则为参考的表;否则为 0 |
| confupdtype | char | 外键更新动作代码 | |
| confdeltype | char | 外键删除动作代码 | |
| confmatchtype | char | 外键匹配类型 | |
| conkey | int2[] | pg_attribute.attnum | 如果是表约束,则是约束控制的字段列表 |
| confkey | int2[] | pg_attribute.attnum | 如果是一个外键,是参考的字段的列表 |
| conbin | text | 如果是检查约束,那就是其表达式的内部形式 | |
| consrc | text | 如果是检查约束,则是表达式的人类可读形式 |
注意: pg_class.relchecks 需要和在此表上为给定关系找到的检查约束的数目一致。