sys_constraint(表约束)¶
这个系统表存储表上的 CHECK,PRIMARY KEY,UNIQUE,和 FOREIGN KEY 约束。(字段约束不会得到特殊对待。每个字段约束都等效于某些表约束。)参阅 CREATE TABLE 获取更多信息。注意: NOT NULL 约束在sys_attribute表中表现。
在域上面的 CHECK 约束存储在这里。全局断言(Global ASSERTIONS)(一种目前还不支持的 SQL 特性)将来的某一天也可能出现在这里。
| 列名 | 类型 | 描述 |
|---|---|---|
| OID | OID | 约束的OID |
| CONNAME | NAME | 约束名字(不一定是唯一的) |
| CONNAMESPACE | OID | 包含这个约束的名字空间的 OID |
| CONRELID | OID | 这个约束所在的表;如果不是表约束则为 0 |
| CONTYPID | OID | 这个约束所在的域;如果不是一个域约束则为 0 |
| CONFRELID | OID | 如果是外键,则为参考的表;否则为 0 |
| CONTYPE | "CHAR" | 'c' = 检查约束, 'f' = 外键约束, 'p' = 主键约束, 'u' = 唯一约束, 'P' = 主键约束, 'U' = 唯一约束('P' 和 'U' 是使用 'alter table xx add CONSTRAINT conName PRIMARY KEY(keyname) using index indName;' 创建出来的类型) |
| CONDEFERRABLE | BOOLEAN | 这个约束是否可以推迟 |
| CONDEFERRED | BOOLEAN | 缺省时这个约束是否推迟 |
| CONFUPDTYPE | "CHAR" | 外键更新动作代码 |
| CONFDELTYPE | "CHAR" | 外键删除动作代码 |
| CONFMATCHTYPE | "CHAR" | 外键匹配类型 |
| CONENABLE | BOOLEAN | 约束是否启用 |
| CONVALIDATE | BOOLEAN | 约束是否验证 |
| CONCHANGETIME | TIMESTAMP(8) WITH TIME ZONE | 最后一次修改约束状态的时间 |
| CONKEY | SMALLINT[] | 如果是表约束,则是约束控制的字段列表 |
| CONFKEY | SMALLINT[] | 如果是一个外键,则是参考的字段的列表 |
| CONBIN | TEXT | 如果是检查约束,则是表达式的内部形式 |
| CONSRC | TEXT | 如果是检查约束,则是表达式的可读形式 |