53.1. Обзор
В Таблице 53.1 перечислены системные каталоги. Подробное описание каждого каталога следует далее.
Большинство системных каталогов копируются из базы-шаблона при создании базы данных и затем принадлежат этой базе. Но некоторые каталоги физически разделяются всеми базами данных в кластере; это отмечено в их описаниях.
Таблица 53.1. Системные каталоги
Имя каталога | Предназначение |
---|---|
pg_aggregate | агрегатные функции |
pg_am | индексные методы доступа |
pg_amop | операторы методов доступа |
pg_amproc | опорные функции методов доступа |
pg_attrdef | значения столбцов по умолчанию |
pg_attribute | столбцы таблиц («атрибуты») |
pg_authid | идентификаторы для авторизации (роли) |
pg_auth_members | отношения членства для объектов авторизации |
pg_cast | приведения (преобразования типов данных) |
pg_class | таблицы, индексы, последовательности, представления («отношения») |
pg_collation | правила сортировки (параметры локали) |
pg_constraint | ограничения-проверки, ограничения уникальности, ограничения первичного ключа и внешних ключей |
pg_conversion | информация о перекодировках |
pg_database | базы данных в этом кластере |
pg_db_role_setting | параметры, задаваемые на уровне ролей и баз данных |
pg_default_acl | права по умолчанию для различных типов объектов |
pg_depend | зависимости между объектами базы данных |
pg_description | описания или комментарии к объектам базы данных |
pg_enum | определения меток и значений перечислений |
pg_event_trigger | событийные триггеры |
pg_extension | установленные расширения |
pg_foreign_data_wrapper | определения обёрток сторонних данных |
pg_foreign_server | определения сторонних серверов |
pg_foreign_table | дополнительные свойства сторонних таблиц |
pg_index | дополнительные свойства индексов |
pg_inherits | иерархия наследования таблиц |
pg_init_privs | начальные права для объектов |
pg_language | языки для написания функций |
pg_largeobject | страницы данных для больших объектов |
pg_largeobject_metadata | метаданные для больших объектов |
pg_namespace | схемы |
pg_opclass | классы операторов методов доступа |
pg_operator | операторы |
pg_opfamily | семейства операторов методов доступа |
pg_partitioned_table | информация о ключах разбиения таблиц |
pg_pltemplate | данные шаблонов для процедурных языков |
pg_policy | политики защиты строк |
pg_proc | функции и процедуры |
pg_publication | публикации для логической репликации |
pg_publication_rel | сопоставление отношений с публикациями |
pg_range | информация о типах диапазонов |
pg_replication_origin | зарегистрированные источники репликации |
pg_rewrite | правила перезаписи запросов |
pg_seclabel | метки безопасности для объектов базы данных |
pg_sequence | информация о последовательностях |
pg_shdepend | зависимости общих объектов |
pg_shdescription | комментарии к общим объектам |
pg_shseclabel | метки безопасности для общих объектов баз данных |
pg_statistic | статистика планировщика |
pg_statistic_ext | расширенная статистика планировщика |
pg_subscription | подписки логической репликации |
pg_subscription_rel | состояние отношений для подписок |
pg_tablespace | табличные пространства в этом кластере баз данных |
pg_transform | трансформации (тип данных для преобразований процедурных языков) |
pg_trigger | триггеры |
pg_ts_config | конфигурации текстового поиска |
pg_ts_config_map | сопоставления фрагментов в конфигурациях текстового поиска |
pg_ts_dict | словари текстового поиска |
pg_ts_parser | анализаторы текстового поиска |
pg_ts_template | шаблоны текстового поиска |
pg_type | типы данных |
pg_user_mapping | сопоставления пользователей для сторонних серверов |
45.4. Expressions
All expressions used in PL/pgSQL statements are processed using the server's main SQL executor. For example, when you write a PL/pgSQL statement like
IF expression
THEN ...
PL/pgSQL will evaluate the expression by feeding a query like
SELECT expression
to the main SQL engine. While forming the SELECT
command, any occurrences of PL/pgSQL variable names are replaced by query parameters, as discussed in detail in Section 45.12.1. This allows the query plan for the SELECT
to be prepared just once and then reused for subsequent evaluations with different values of the variables. Thus, what really happens on first use of an expression is essentially a PREPARE
command. For example, if we have declared two integer variables x
and y
, and we write
IF x < y THEN ...
what happens behind the scenes is equivalent to
PREPARE statement_name
(integer, integer) AS SELECT $1 < $2;
and then this prepared statement is EXECUTE
d for each execution of the IF
statement, with the current values of the PL/pgSQL variables supplied as parameter values. Normally these details are not important to a PL/pgSQL user, but they are useful to know when trying to diagnose a problem. More information appears in Section 45.12.2.
Since an expression
is converted to a SELECT
command, it can contain the same clauses that an ordinary SELECT
would, except that it cannot include a top-level UNION
, INTERSECT
, or EXCEPT
clause. Thus for example one could test whether a table is non-empty with
IF count(*) > 0 FROM my_table THEN ...
since the expression
between IF
and THEN
is parsed as though it were SELECT count(*) > 0 FROM my_table
. The SELECT
must produce a single column, and not more than one row. (If it produces no rows, the result is taken as NULL.)