返回介绍

I. 教程

II. SQL 语言

III. 服务器管理

IV. 客户端接口

V. 服务器端编程

VI. 参考手册

VII. 内部

VIII. 附录

43.16. pg_depend

发布于 2019-09-30 03:12:42 字数 2355 浏览 986 评论 0 收藏 0

pg_depend 表记录数据库对象之间的依赖关系。这个信息允许 DROP 命令找出哪些其它对象必须由 DROP CASCADE 删除,或者是在 DROP RESTRICT 的情况下避免删除。

这个表的功能类似 pg_shdepend ,用于记录那些在数据库集群之间共享的对象之间的依赖性关系。

表43-16. pg_depend 字段

名字类型引用描述
classidoidpg_class.oid有倚赖对象所在系统表的 OID
objidoid任何 OID 属性指定的有依赖对象的 OID
objsubidint4对于表字段,这个是该属性的字段数(objidclassid 引用表本身)。对于所有其它对象类型,目前这个字段是零。
refclassidoidpg_class.oid被引用对象所在的系统表的 OID
refobjidoid任意 OID 属性指定的被引用对象的 OID
refobjsubidint4对于表字段,这个是该字段的字段号(refobjidrefclassid 引用表本身)。对于所有其它对象类型,目前这个字段是零。
deptypechar一个定义这个依赖关系特定语义的代码。见下文。

在所有情况下,一个 pg_depend 记录表示被引用的对象不能在有依赖的对象被删除前删除。不过,这里还有几种由 deptype 定义的情况:

DEPENDENCY_NORMAL (n)

独立创建的对象之间的一般关系。有倚赖的对象可以在不影响被引用对象的情况下删除。被引用对象只有在声明了 CASCADE 的情况下删除,这时有依赖的对象也被删除。例子:一个表字段对其数据类型有一般依赖关系。

DEPENDENCY_AUTO (a)

有依赖对象可以和被引用对象分别删除,并且如果删除了被引用对象则应该被自动删除(不管是 RESTRICTCASCADE 模式)。例子:一个表上面的命名约束是在该表上的自动依赖关系,因此如果删除了表,它也会被删除。

DEPENDENCY_INTERNAL (i)

有依赖的对象是作为被引用对象的一部分创建的,实际上只是它的内部实现的一部分。DROP 有依赖对象是不能直接允许的(将告诉用户发出一条删除被引用对象的 DROP)。一个对被引用对象的 DROP 将传播到有依赖对象,不管是否声明了 CASCADE 。例子:一个创建来强制外键约束的触发器在该约束的 pg_constraint 记录上是标记为内部依赖的。

DEPENDENCY_PIN (p)

没有有依赖对象;这种类型的记录标志着系统本身依赖于被引用对象,因此这个对象决不能被删除。这种类型的记录只有在 initdb 的时候创建。有依赖对象的字段里是零。

将来可能还会有其它依赖的风格。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文