pg_shdepend #目录 pg_shdepend 记录数据库对象和共享对象(如角色)之间的依赖关系。此信息允许 PostgreSQL 确保在尝试删除这些对象之前,它们没有被引用。
另请参见 pg_depend,它对涉及单个数据库中对象的依赖关系执行类似的功能。
与大多数系统目录不同,pg_shdepend 在集群的所有数据库中共享:每个集群只有一个 pg_shdepend 副本,而不是每个数据库一个。
表 53.48. pg_shdepend 列
|
列类型 说明 |
|---|
|
依赖对象所在的数据库的 OID,或共享对象的 OID 为零 |
|
依赖对象所在的系统目录的 OID |
|
特定依赖对象的 OID |
|
对于表列,这是列号( |
|
引用的对象所在的系统目录的 OID(必须是共享目录) |
|
特定引用的对象的 OID |
|
定义此依赖关系的特定语义的代码;参见文本 |
在所有情况下,pg_shdepend 条目表示在不删除依赖对象的情况下无法删除引用的对象。但是,deptype 标识了几个子类型
SHARED_DEPENDENCY_OWNER (o)引用的对象(必须是角色)是依赖对象的拥有者。
SHARED_DEPENDENCY_ACL (a)引用的对象(必须是角色)在依赖对象的 ACL(访问控制列表,即权限列表)中被提及。(不会为对象的拥有者创建 SHARED_DEPENDENCY_ACL 条目,因为拥有者无论如何都将拥有一个 SHARED_DEPENDENCY_OWNER 条目。)
SHARED_DEPENDENCY_POLICY (r)引用的对象(必须是角色)被提及为依赖策略对象的 target。
SHARED_DEPENDENCY_TABLESPACE (t)引用的对象(必须是表空间)被提及为没有存储空间的关系的表空间。
将来可能需要其他依赖类型。特别注意,当前定义仅支持角色和表空间作为引用的对象。
与 pg_depend 目录一样,在 initdb 期间创建的大多数对象都被视为 “已固定”。不会在 pg_shdepend 中创建任何条目,其中固定对象作为引用的对象或依赖的对象。
如果您在文档中看到任何不正确的内容,与您对特定功能的体验不符或需要进一步澄清,请使用 此表单 报告文档问题。