v_sys_constraint

这个系统表存储表上的 CHECK,PRIMARY KEY,UNIQUE,和 FOREIGN KEY 约束。(字段约束不会得到特殊对待。每个字段约束都等效于某些表约束。) 参阅 CREATE TABLE 获取更多信息。注意: NOT NULL 约束在sys_attribute表中表现。

在域上面的 CHECK 约束存储在这里。全局断言(Global ASSERTIONS)(一种目前还不支持的 SQL 特性)将来的某一天也可能出现在这里。

表175 V_SYS_CONSTRAINT 结构
列名 类型 描述
OID OID 约束OID
TABLEOID OID 表的OID
CONNAMESPACE OID 包含这个约束的名字空间的 OID
CONRELID OID 这个约束所在的表;如果不是表约束则为 0
CONTYPID OID 这个约束所在的域;如果不是一个域约束则为 0
CONFRELID OID 如果是外键,则为参考的表;否则为 0
CONNAME NAME 约束名字(不一定是唯一的)
CONTYPE "CHAR" 'c' = 检查约束, 'f' = 外键约束,'p' = 主键约束, 'u' = 唯一约束
CONDEFERRABLE BOOLEAN 这个约束是否可以推迟
CONDEFERRED BOOLEAN 缺省时这个约束是否推迟
CONFUPDTYPE "CHAR" 外键更新动作代码
CONFDELTYPE "CHAR" 外键删除动作代码
CONFMATCHTYPE "CHAR" 外键匹配类型
CONENABLE BOOLEAN 约束是否启动;如果不启动则为0
CONKEY SMALLINT[] 如果是表约束,则是约束控制的字段列表
CONFKEY SMALLINT[] 如果是一个外键,是参考的字段的列表
CONBIN TEXT 如果是检查约束,那就是其表达式的内部形式
CONSRC TEXT 如果是检查约束,则是表达式的人类可读形式