Настроить путь схемы Postgresql
Мне нужно установить путь к схеме в Postgres, чтобы не каждый раз указывать таблицу точек схемы, например, schema2.table
. Установить путь к схеме:
SET SCHEMA PATH a,b,c
кажется, работает только для одного сеанса запроса на Mac, после того, как я закрываю окно запроса, переменная пути возвращается к значению по умолчанию.
Как я могу сделать это постоянным?
Ответы
Ответ 1
(И если у вас нет доступа администратора к серверу)
ALTER ROLE <your_login_role> SET search_path TO a,b,c;
Две важные вещи, о которых нужно знать:
- Когда имя схемы не простое, его необходимо обернуть в двойные кавычки.
- Вопрос, по которому вы устанавливаете схемы по умолчанию
a, b, c
, имеет значение, так как это также порядок, в котором схемы будут искать таблицы. Поэтому, если у вас есть одно и то же имя таблицы в нескольких схемах по умолчанию, не будет никакой двусмысленности, сервер всегда будет использовать таблицу из первой схемы, указанной вами для search_path
.
Ответ 2
Вы можете установить значение по умолчанию search_path
на уровне базы данных:
ALTER DATABASE <database_name> SET search_path TO schema1,schema2;
Или на уровне пользователя или роли:
ALTER ROLE <role_name> SET search_path TO schema1,schema2;
Или, если у вас есть общая схема по умолчанию во всех ваших базах данных, вы можете установить общесистемный вариант по умолчанию в файле конфигурации с опцией search_path.
Когда создается база данных, она создается по умолчанию из скрытой базы данных "шаблонов" с именем template1, вы можете изменить эту базу данных, чтобы указать новый путь поиска по умолчанию для всех баз данных, созданных в будущем. Вы также можете создать другую базу данных шаблонов и использовать CREATE DATABASE <database_name> TEMPLATE <template_name>
для создания своих баз данных.
Ответ 3
Джош прав, но он оставил одну вариацию:
ALTER ROLE <role_name> IN DATABASE <db_name> SET search_path TO schema1,schema2;
Задайте путь поиска для пользователя в одной конкретной базе данных.