pg_constraint #目录pg_constraint存储表上的检查约束、非空约束、主键约束、唯一约束、外键约束和排他约束。 (列约束不会被特殊对待。每一个列约束都等价于某种表约束。)
用户定义的约束触发器(使用CREATE CONSTRAINT TRIGGER创建)也会在这个表中产生一项。
域上的检查约束也存储在这里。
Table 50.13. pg_constraint 列
|
列类型 描述 |
|---|
|
行标识符 |
|
约束名字(不需要唯一!) |
|
包含此约束的名字空间的OID |
|
|
|
该约束是否能被延迟? |
|
该约束是否默认被延迟? |
|
该约束是否会被强制执行? |
|
该约束是否已经验证? |
|
该约束所在的表,如果不是表约束则为零 |
|
该约束所在的域,如果不是域约束则为0 |
|
如果该约束是唯一、主键、外键或排他约束,此列表示支持此约束的索引,否则为零 |
|
如果这是一个分区中的约束,则是父分区表中对应的约束;否则为零 |
|
如果此约束是一个外键约束,此列为被引用的表,否则为零 |
|
外键更新动作代码: |
|
外键删除动作代码: |
|
外键匹配类型: |
|
此约束是定义在关系本地。注意一个约束可以同时是本地定义和继承。 |
|
该约束直接继承自多少个祖先。祖先数量非零的约束不能被删除,也不能被重命名。 |
|
为真表示此约束被定义在关系本地。它是一个不可继承约束。 |
|
如果该约束被定义为 |
|
如果是一个表约束(包括外键但不包括约束触发器),此列是被约束列的列表 |
|
如果是一个外键,此列是被引用列的列表 |
|
如果是一个外键,此列是用于PK = FK比较的等值操作符的列表 |
|
如果是一个外键,此列是用于PK = PK比较的等值操作符的列表 |
|
如果是一个外键,此列是用于FK = FK比较的等值操作符的列表 |
|
如果是排他约束或 |
|
如果是一个检查约束,此列是表达式的一个内部表示。建议使用 |
在一个排他约束的情况中, conkey只对约束元素是单一列引用时有用。 对于其他情况,conkey为0且必须查阅相关索引来发现被约束的表达式。 (对于索引,conkey因此和pg_index.indkey具有相同的内容)。
pg_class.relchecks需要和每个关系在此目录中的检查约束数量保持一致。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。