认识GBase 8c 系统表之pg_constraint

pg_constraint系统表存储表上的检查约束、主键、唯一约束和外键约束。

名称

类型

引用

描述

oid

oid

行标识符(隐藏属性,必须被显式选择才会显示)

conname

name

约束名字(不需要唯一!)

connamespace

oid

pg_namespace.oid

包含此约束的名字空间的OID

contype

char

c = 检查约束, f = 外键约束, p = 主键约束, u = 唯一约束, t = 约束触发器, x = 排他约束

condeferrable

bool

该约束是否能被延迟?

condeferred

bool

该约束是否默认被延迟?

convalidated

bool

此约束是否被验证过?当前对于外键和检查约束只能是假

conrelid

oid

pg_class.oid

该约束所在的表,如果不是表约束则为0

contypid

oid

pg_type.oid

该约束所在的域,如果不是域约束则为0

conindid

oid

pg_class.oid

如果该约束是唯一、主键、外键或排他约束,此列表示支持此约束的索引,否则为0

confrelid

oid

pg_class.oid

如果此约束是一个外键约束,此列为被引用的表,否则为0

confupdtype

char

外键更新动作代码: a = 无动作, r = 限制, c = 级联, n = 置空, d = 置为默认值

confdeltype

char

外键删除动作代码: a = 无动作, r = 限制, c = 级联, n = 置空, d = 置为默认值

confmatchtype

char

外键匹配类型: f = 完全, p = 部分, s = 简单

conislocal

bool

此约束是定义在关系本地。注意一个约束可以同时是本地定义和继承。

coninhcount

int4

此约束的直接继承祖先数目。一个此列非零的约束不能被删除或重命名。

connoinherit

bool

为真表示此约束被定义在关系本地。它是一个不可继承约束。

conkey

int2[]

pg_attribute.attnum

如果是一个表约束(包括外键但不包括约束触发器),此列是被约束列的列表

confkey

int2[]

pg_attribute.attnum

如果是一个外键,此列是被引用列的列表

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

如果是一个排他约束,此列是没列排他操作符的列表

conbin

pg_node_tree

如果是一个检查约束,此列是表达式的一个内部表示

consrc

text

如果是一个检查约束,此列是表达式的一个人类可读的表示

注意:consrc在被引用的对象改变之后不会被更新,它不会跟踪字段的名字修改。与其依赖这个字段,最好还是使用pg_get_constraintdef()来抽取一个检查约束的定义。

pg_class.relchecks需要和在此表上为给定关系找到的检查约束的数目一致。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值