Документация по PostgreSQL 9.4.1 | |||
---|---|---|---|
Пред. | Уровень выше | Глава 48. Системные каталоги | След. |
48.41. pg_shdepend
В каталоге pg_shdepend записываются отношения зависимости между объектами баз данных и разделяемыми объектами, такими как роли. Эта информация позволяет PostgreSQL удостовериться, что эти объекты не используется, прежде чем удалять их.
Также смотрите каталог pg_depend, который играет подобную роль в отношении зависимостей объектов в одной базе данных.
В отличие от большинства системных каталогов, pg_shdepend разделяется всеми базами данных кластера: есть только один экземпляр pg_shdepend в кластере, а не отдельные в каждой базе данных.
Таблица 48-41. Колонки pg_shdepend
Имя | Тип | Ссылки | Описание |
---|---|---|---|
dbid | oid | pg_database.oid | OID базы данных, в которой находится зависимый объект, или ноль, если это глобальный объект |
classid | oid | pg_class.oid | OID системного каталога, в котором находится зависимый объект |
objid | oid | любая колонка OID | OID определённого зависимого объекта |
objsubid | int4 | Для колонки таблицы это номер колонки (objid и classid указывают на саму таблицу). Для всех других типов объектов это поле содержит ноль. | |
refclassid | oid | pg_class.oid | OID системного каталога, к которому относится вышестоящий объект (это должен быть разделяемый каталог) |
refobjid | oid | любая колонка OID | OID определённого вышестоящего объекта |
deptype | char | Код, определяющий конкретную семантику данного отношения зависимости; см. текст |
Во всех случаях, запись в pg_shdepend показывает, что вышестоящий объект нельзя удалить, не удаляя подчинённый объект. Однако есть несколько подвидов зависимости, задаваемых в поле deptype:
- SHARED_DEPENDENCY_OWNER (o)
Вышестоящий объект (это должна быть роль) является владельцем зависимого объекта.
- SHARED_DEPENDENCY_ACL (a)
Вышестоящий объект (это должна быть роль) упоминается в ACL (списке управления доступом, то есть списке прав) подчинённого объекта. (Запись SHARED_DEPENDENCY_ACL не создаётся для владельца объекта, так как для владельца всё равно имеется запись SHARED_DEPENDENCY_OWNER.)
- SHARED_DEPENDENCY_PIN (p)
Зависимый объект отсутствует; этот тип записи показывает, что система сама зависит от вышестоящего объекта, так что этот объект нельзя удалять ни при каких условиях. Записи этого типа создаются только командой initdb. Поля зависимого объекта в такой записи содержат нули.
В будущем могут появиться и другие подвиды зависимости. Заметьте в частности, что с текущим определением вышестоящими объектами могут быть только роли.
Пред. | Начало | След. |
pg_seclabel | Уровень выше | pg_shdescription |