pg_constraint
pg_constraint¶
pg_constraint
系统目录表储存表上的检查、主键、唯一和外键约束。 列约束不被特别对待。 每个列约束都等效于某种表约束。
非空约束在pg_attribute目录表中表示。
域上的检查约束也储存在这里。
列 | 类型 | 参考 | 描述 |
---|---|---|---|
oid |
oid | 行标识符 | |
conname |
name | 约束名称(不一定唯一!) | |
connamespace |
oid | pg_namespace.oid | 包含约束的命名空间(schema)的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 | 如果是一个检查约束,则表示表达式的内部表示。 | |
convalidated |
boolean | 此约束是否被验证过?当前对于外键和检查约束只能是假。 | |
conenabled |
boolean | 是否启用约束 | |
conindid |
oid | pg_class.oid | 如果该约束是唯一、主键、外键或排他约束,此列表表示支持此约束的索引,否则为0。 |
conparentid |
oid | pg_constraint.oid | 如果这是一个分区中的约束,则是父分区表中对应的约束,否则为0。 |
conislocal |
boolean | 此约束时定义在关系本地。注意一个约束可以同时是本地定义和继承。 | |
coninhcount |
integer | 此约束的直接继承祖先数目。一个此列非零的约束不能被删除或重命名。 | |
connoinherit |
boolean | 为真表示此约束被定义在关系本地。它是一个不可继承约束。 | |
conpfeqop |
oid[] | pg_operator.oid | 如果是一个外键,此列是用于 PK = FK 比较的等值操作符的列表。 |
conppeqop |
oid[] | pg_operator.oid | 如果是一个外键,此列是用于 PK = PK 比较的等值操作符的列表。 |
conffeqop |
oid[] | pg_operator.oid | 如果是一个外键,此列是用于 FK = FK 比较的等值操作符的列表。 |
conexclop |
oid[] | pg_operator.oid | 如果是一个排他约束,此列是每列排他操作符的列表。 |
Table 1. pg_catalog.pg_constraint