psql
psql — Интерактивный терминал Postgres Pro
Синтаксис
psql
[параметр
...] [имя_бд
[имя_пользователя
]]
Описание
Программа psql — это терминальный клиент для работы с Postgres Pro. Она позволяет интерактивно вводить запросы, передавать их в Postgres Pro и видеть результаты. Также запросы могут быть получены из файла или из аргументов командной строки. Кроме того, psql предоставляет ряд метакоманд и различные возможности, подобные тем, что имеются у командных оболочек, для облегчения написания скриптов и автоматизации широкого спектра задач.
Параметры
-a
--echo-all
Отправляет в стандартный вывод все непустые входные строки по мере их чтения. (Это не относится к строкам, считанным в интерактивном режиме.) Эквивалентно установке переменной
ECHO
в значениеall
.-A
--no-align
Переключение на невыровненный режим вывода. (По умолчанию, наоборот, используется выровненный режим вывода.)
-b
--echo-errors
Печатает все команды SQL с ошибками в стандартный вывод. Равнозначно присвоению переменной
ECHO
значенияerrors
.-c
команда
--command=
команда
Передаёт psql
команду
для выполнения. Этот ключ можно повторять и комбинировать в любом порядке с ключом-f
. Когда указывается-c
или-f
, psql не читает команды со стандартного ввода; вместо этого она завершается сразу после обработки всех ключей-c
и-f
по порядку.Заданная
команда
должна быть либо командной строкой, которая полностью интерпретируется сервером (т. е. не использует специфические функции psql), либо одиночной командой с обратной косой чертой. Таким образом, используя-c
, нельзя смешивать метакоманды SQL и psql. Но это можно сделать, передав несколько ключей-c
или передав строку в psql через канал:psql -c '\x' -c 'SELECT * FROM foo;'
или
echo '\x \\ SELECT * FROM foo;' | psql
(
\\
— разделитель метакоманд.)Каждая строка SQL-команд, заданная ключом
-c
, передаётся на сервер как один запрос. Поэтому сервер выполняет её в одной транзакции, даже когда эта строка содержит несколько команд SQL, если только в ней не содержатся явные командыBEGIN
/COMMIT
, разделяющие её на несколько транзакций. Кроме того, psql печатает результат только последней SQL-команды в строке. Это отличается от поведения, когда та же строка считывается из файла или подаётся на стандартный ввод psql, так как в последнем случае psql передаёт каждую команду SQL отдельно.Из-за такого поведения указание нескольких команд в одной строке
-c
часто приводит к неожиданным результатам. Поэтому лучше использовать несколько ключей-c
или подавать команды на стандартный ввод psql, применяя либо echo, как показано выше, либо создаваемый прямо в оболочке документ, например:psql <<EOF \x SELECT * FROM foo; EOF
-d
имя_бд
--dbname=
имя_бд
Указывает имя базы данных для подключения. Равнозначно указанию
имя_бд
в первом аргументе, не являющемся ключом, в командной строке. Вместо имени может задаваться строка подключения. В этом случае параметры в строке подключения переопределяют одноимённые параметры, заданные в командной строке.-e
--echo-queries
Посылает все команды SQL, отправленные на сервер, ещё и на стандартный вывод. Эквивалентно установке переменной
ECHO
в значениеqueries
.-E
--echo-hidden
Отображает фактические запросы, генерируемые
\d
и другими командами, начинающимися с \. Это можно использовать для изучения внутренних операций в psql. Эквивалентно установке переменнойECHO_HIDDEN
значенияon
.-f
имя_файла
--file=
имя_файла
Читает команды из файла
имя_файла
, а не из стандартного ввода. Этот ключ можно повторять и комбинировать в любом порядке с ключом-c
. Если указан ключ-c
или-f
, программа psql не читает команды со стандартного ввода; вместо этого она завершается после обработки всех ключей-c
и-f
по очереди. Не считая этого, данный ключ по большому счёту равнозначен метакоманде\i
.Если
имя_файла
задано символом-
(минус), считывается стандартный ввод до признака конца файла или до метакоманды\q
. Это позволяет перемежать интерактивный ввод с вводом из файлов. Однако заметьте, что Readline в этом случае не применяется (так же, как и с ключом-n
).Использование этого параметра немного отличается от
psql <
. В основном, оба варианта будут делать то, что вы ожидаете, но симя_файла
-f
доступны некоторые полезные свойства, такие как сообщения об ошибках с номерами строк. Также есть небольшая вероятность, что запуск в таком режиме будет быстрее. С другой стороны, вариант с перенаправлением ввода из командного интерпретатора (в теории) гарантирует получение точно такого же вывода, какой вы получили бы, если бы ввели всё вручную.-F
разделитель
--field-separator=
разделитель
Использование
разделитель
в качестве разделителя полей при невыровненном режиме вывода. Эквивалентно\pset fieldsep
или\f
.-h
компьютер
--host=
компьютер
Указывает имя компьютера, на котором работает сервер. Если значение начинается с косой черты, оно определяет каталог Unix-сокета.
-H
--html
Включает табличный вывод в формате HTML. Эквивалентно
\pset format html
или команде\H
.-l
--list
Выводит список всех доступных баз данных и завершает работу. Другие параметры, не связанные с соединением, игнорируются. Это похоже на метакоманду
\list
.-L
имя_файла
--log-file=
имя_файла
В дополнение к обычному выводу, записывает вывод результатов всех запросов в файл
имя_файла
.-n
--no-readline
Отключает использование Readline для редактирования командной строки и использования истории команд. Может быть полезно для выключения расширенных действий клавиши табуляции при вырезании и вставке.
-o
имя_файла
--output=
имя_файла
Записывает вывод результатов всех запросов в файл
имя_файла
. Эквивалентно команде\o
.-p
порт
--port=
порт
Указывает TCP-порт или расширение файла локального Unix-сокета, через который сервер принимает подключения. Значение по умолчанию определяется переменной среды
PGPORT
, если она установлена, либо числом, заданным при компиляции, обычно 5432.-P
присвоение
--pset=
присвоение
Задаёт параметры печати, в стиле команды
\pset
. Обратите внимание, что имя параметра и значение разделяются знаком равенства, а не пробела. Например, чтобы установить формат вывода в LaTeX, нужно написать-P format=latex
.-q
--quiet
Указывает, что psql должен работать без вывода дополнительных сообщений. По умолчанию, выводятся приветствия и различные информационные сообщения. Этого не произойдёт с использованием данного параметра. Полезно вместе с параметром
-c
. Этот же эффект можно получить, установив для переменнойQUIET
значениеon
.-R
разделитель
--record-separator=
разделитель
Использует
разделитель
как разделитель записей при невыровненном режиме вывода. Эквивалентно команде\pset recordsep
.-s
--single-step
Запуск в пошаговом режиме. Это означает, что пользователь будет подтверждать выполнение каждой команды, отправляемой на сервер, с возможностью отменить выполнение. Используется для отладки скриптов.
-S
--single-line
Запуск в однострочном режиме, при котором символ новой строки завершает SQL-команды, так же как это делает точка с запятой.
Примечание
Этот режим реализован для тех, кому он нужен, но это не обязательно означает, что и вам нужно его использовать. В частности, если смешивать в одной строке команды SQL и метакоманды, порядок их выполнения может быть не всегда понятен для неопытного пользователя.
-t
--tuples-only
Отключает вывод имён столбцов и результирующей строки с количеством выбранных записей. Эквивалентно команде
\t
.-T
параметры_таблицы
--table-attr=
параметры_таблицы
Задаёт атрибуты, которые будут вставлены в тег HTML
table
. За подробностями обратитесь к описанию\pset
.-U
имя_пользователя
--username=
имя_пользователя
Использовать для подключения к базе данных
имя_пользователя
вместо подразумеваемого по умолчанию. (Разумеется, это потребует соответствующего разрешения.)-v
присвоение
--set=
присвоение
--variable=
присвоение
Выполняет присвоение значения переменной, как метакоманда
\set
. Обратите внимание на то, что необходимо разделить имя переменной и значение (при наличии) знаком равенства в командной строке. Чтобы сбросить переменную, опустите знак равенства. Чтобы установить пустое значение, поставьте знак равенства, но опустите значение. Присваивания выполняются на очень ранней стадии запуска, поэтому если переменные зарезервированы для внутренних целей, то позже они могут быть перезаписаны.-V
--version
Выводит версию psql и завершает работу.
-w
--no-password
Не выдавать запрос на ввод пароля. Если сервер требует аутентификацию по паролю и пароль нельзя получить из других источников, например из файла
.pgpass
, попытка соединения не удастся. Этот параметр может быть полезен в пакетных заданиях и скриптах, где нет пользователя, который вводит пароль.Обратите внимание, что этот параметр действует на протяжении всей сессии и, таким образом, влияет на метакоманду
\connect
, так же как и на первую попытку соединения.-W
--password
Принудительно запрашивать пароль перед подключением к базе данных, даже если он не будет использоваться.
Если сервер требует аутентификацию по паролю и пароль нельзя получить из других источников, например из файла
.pgpass
, psql запросит пароль в любом случае. Однако чтобы понять, что требуется пароль, psql лишний раз подключится к серверу. Поэтому иногда имеет смысл ввести-W
, чтобы исключить эту ненужную попытку подключения.Обратите внимание, что этот параметр действует на протяжении всей сессии и, таким образом, влияет на метакоманду
\connect
, так же как и на первую попытку соединения.-x
--expanded
Включает режим развёрнутого вывода таблицы. Эквивалентно команде
\x
.-X,
--no-psqlrc
Не читать стартовые файлы (ни общесистемный файл
psqlrc
, ни пользовательский файл~/.psqlrc
).-z
--field-separator-zero
Установить нулевой байт в качестве разделителя полей для невыровненного режима вывода.
-0
--record-separator-zero
Установить нулевой байт в качестве разделителя записей для невыровненного режима вывода. Это полезно при взаимодействии с другими программами, например, с
xargs -0
.-1
--single-transaction
Этот параметр может применяться только в сочетании с одним или несколькими параметрами
-c
и/или-f
. С ним psql выполняет командуBEGIN
перед обработкой первого такого параметра иCOMMIT
после последнего, заворачивая таким образом все команды в одну транзакцию. Это гарантирует, что либо все команды завершатся успешно, либо никакие изменения не сохранятся.Если в самих этих командах содержатся операторы
BEGIN
,COMMIT
илиROLLBACK
, этот параметр не даст желаемого эффекта. Кроме того, если какая-либо отдельная команда не может выполняться внутри блока транзакции, с этим параметром вся транзакция прервётся с ошибкой.-?
--help[=
тема
]Показать справку по psql и завершиться. Необязательный параметр
тема
(по умолчаниюoptions
) выбирает описание интересующей части psql:commands
описывает команды psql с обратной косой чертой;options
описывает параметры командной строки, которые можно передать psql; аvariables
выдаёт справку по переменным конфигурации psql.
Код завершения
При нормальном завершении psql возвращает 0 в командную оболочку ОС, 1 — если произошла фатальная ошибка в самом psql (например, нехватка памяти, файл не найден), 2 — при неудачном соединении с сервером неинтерактивного сеанса, 3 — при ошибке в скрипте и установленной переменной ON_ERROR_STOP
.
Использование
Подключение к базе данных
psql это клиент для Postgres Pro. Для подключения к базе данных нужно знать имя базы данных, имя сервера, номер порта сервера и имя пользователя, под которым вы хотите подключиться. Эти свойства можно задать через аргументы командной строки, а именно -d
, -h
, -p
и -U
соответственно. Если в командной строке есть аргумент, который не относится к параметрам psql, то он используется в качестве имени базы данных (или имени пользователя, если база данных уже задана). Задавать все эти аргументы необязательно, у них есть разумные значения по умолчанию. Если опустить имя сервера, psql будет подключаться через Unix-сокет к локальному серверу, либо подключаться к localhost
по TCP/IP в системах, не поддерживающих UNIX-сокеты. Номер порта по умолчанию определяется во время компиляции. Поскольку сервер базы данных использует то же значение по умолчанию, чаще всего указывать номер порта не нужно. Имя пользователя по умолчанию, как и имя базы данных по умолчанию, совпадает с именем пользователя в операционной системе. Заметьте, что просто так подключаться к любой базе данных под любым именем пользователя вы не сможете. Узнать о ваших правах можно у администратора баз данных.
Если значения по умолчанию не подходят, можно сэкономить на вводе параметров подключения, установив переменные среды PGDATABASE
, PGHOST
, PGPORT
и/или PGUSER
. (Другие переменные среды описаны в Разделе 32.14.) Также удобно иметь файл ~/.pgpass
, чтобы не вводить пароли снова и снова. За дополнительными сведениями обратитесь к Разделу 32.15.
Альтернативный вариант указания параметров подключения — использование строки conninfo
или URI вместо имени базы данных. Этот механизм даёт широкие возможности для управления соединением. Например:
$psql "service=myservice sslmode=require"
$psql postgresql://dbmaster:5433/mydb?sslmode=require
Этот способ также позволяет использовать LDAP для получения параметров подключения, как описано в Разделе 32.17. Более полно все имеющиеся параметры соединения описаны в Подразделе 32.1.2.
Если соединение не может быть установлено по любой причине (например, нет прав, сервер не работает и т. д.), psql вернёт ошибку и прекратит работу.
Если и стандартный ввод, и стандартный вывод являются терминалом, то psql установит кодировку клиента в «auto», и подходящая клиентская кодировка будет определяться из локальных установок (переменная окружения LC_CTYPE
в Unix). Если это работает не так, как ожидалось, кодировку клиента можно изменить, установив переменную окружения PGCLIENTENCODING
.
Ввод SQL-команд
Как правило, приглашение psql состоит из имени базы данных, к которой psql в данный момент подключён, а затем строки =>
. Например:
$ psql testdb
psql (9.6.24.1)
Type "help" for help.
testdb=>
В командной строке пользователь может вводить команды SQL. Обычно введённые строки отправляются на сервер, когда встречается точка с запятой, завершающая команду. Конец строки не завершает команду. Это позволяет разбивать команды на несколько строк для лучшего понимания. Если команда была отправлена и выполнена без ошибок, то результат команды выводится на экран.
Если к базе данных, которая не приведена в соответствие шаблону безопасного использования схем, имеют доступ недоверенные пользователи, начинайте сеанс с удаления доступных им для записи схем из пути поиска (search_path
). Для этого можно добавить options=-csearch_path=
в строку подключения или выполнить команду SELECT pg_catalog.set_config('search_path', '', false)
перед другими командами SQL. Это касается не только psql, но и любых других интерфейсов для выполнения произвольных SQL-команд.
При каждом выполнении команды psql также проверяет асинхронные уведомления о событиях, генерируемые командами LISTEN и NOTIFY.
Комментарии в стиле C передаются для обработки на сервер, в то время как комментарии в стандарте SQL psql удаляет перед отправкой.
Метакоманды
Всё, что вводится в psql не взятое в кавычки и начинающееся с обратной косой черты, является метакомандой psql и обрабатывается самим psql. Эти команды делают psql полезным для задач администрирования и разработки скриптов.
Формат команды psql следующий: обратная косая черта, сразу за ней команда, затем аргументы. Аргументы отделяются от команды и друг от друга любым количеством пробелов.
Чтобы включить пробел в значение аргумента, нужно заключить его в одинарные кавычки. Чтобы включить одинарную кавычку в значение аргумента, нужно написать две одинарные кавычки внутри текста в одинарных кавычках. Всё, что содержится в одинарных кавычках подлежит заменам, принятым в языке C: \n
(новая строка), \t
(табуляция), \b
(backspace), \r
(возврат каретки), \f
(подача страницы), \
цифры
(восьмеричное число), и \x
цифры
(шестнадцатеричное число). Если внутри текста в одинарных кавычках встречается обратная косая перед любым другим символом, то она экранирует этот символ.
Текст аргумента, заключённый в обратные кавычки (`
), считается командной строкой, которая передаётся в командную оболочку ОС. Вывод от этой команды (с удалёнными в конце символами новой строки) заменяет текст в обратных кавычках.
Если внутри аргумента не в кавычках встречается имя переменной psql с предшествующим двоеточием (:
), оно заменяется значением переменной, как описано в Интерполяция SQL.
Некоторые команды принимают идентификатор SQL (например, имя таблицы) в качестве аргумента. Такие аргументы следуют правилам синтаксиса SQL: буквы, не взятые в кавычки, преобразуются в нижний регистр, буквы, взятые в двойные кавычки ("
) предотвращают преобразование регистра и позволяют включать пробелы в идентификатор. Внутри двойных кавычек две двойные кавычки сокращаются до одной. Например, FOO"BAR"BAZ
интерпретируется как fooBARbaz
, а "A weird"" name"
становится A weird" name
.
Разбор аргументов останавливается в конце строки или когда встречается другая обратная косая черта, не внутри кавычек. Обратная косая не внутри кавычек рассматривается как начало новой метакоманды. Специальная последовательность \\
(две обратных косых черты) обозначает окончание аргументов, далее продолжается разбор команд SQL, если таковые имеются. Таким образом, команды SQL и psql можно свободно смешивать в одной строке. Но в любом случае аргументы метакоманды не могут выходить за пределы текущей строки.
Определены следующие метакоманды:
\a
Если текущий режим вывода таблицы невыровненный, то он переключается на выровненный режим. Если текущий режим выровненный, то устанавливается невыровненный. Эта команда поддерживается для обратной совместимости. См.
\pset
для более общего решения.\c
или\connect [ -reuse-previous=
on|off
] [имя_бд
[имя_пользователя
] [компьютер
] [порт
] |строка_подключения
]Устанавливает новое подключение к серверу Postgres Pro. Параметры подключения можно указывать как позиционно (один или несколько по списку: база данных, пользователь, компьютер и порт), так и передавая аргумент
строка_подключения
(подробнее о строках подключения рассказывается в Подразделе 32.1.1). Если аргументы отсутствуют, новое подключение устанавливается с теми же параметрами, что и предыдущее.Указание в параметре
имя_бд
,имя_пользователя
,компьютер
илипорт
значения-
равносильно опущению этого параметра.Новое подключение может повторно использовать параметры предыдущего — не только имя базы данных, пользователя, компьютер и порт, но и, например,
режим_ssl
. По умолчанию параметры используются повторно при позиционной записи, но не когда заданастрока_подключения
. Это поведение может переопределяться первым аргументом,-reuse-previous=on
или-reuse-previous=off
. В случае повторного использования параметров любой параметр, явно не заданный в виде позиционного или встроке_подключения
, заимствуется из параметров текущего подключения. Исключение составляет параметрhostaddr
— если он был задан в предыдущем подключении, а в новом в позиционной записи задаётся другое значениеhost
, значениеhostaddr
сбрасывается. Кроме того, пароль существующего подключения будет использоваться повторно, только если имя пользователя, узел и порт не меняются. Если какой-либо параметр не указан в этой команде и не используется повторно, действует принятое в libpq значение по умолчанию.Если новое подключение успешно установлено, предыдущее подключение закрывается. Если попытка подключения не удалась (неверное имя пользователя, доступ запрещён и т. д.), то предыдущее соединение останется активным, только если psql находится в интерактивном режиме. Если скрипт выполняется неинтерактивно, обработка немедленно останавливается с сообщением об ошибке. Различное поведение выбрано для удобства пользователя в качестве защиты от опечаток с одной стороны и в качестве меры безопасности, не позволяющей случайно запустить скрипты в неправильной базе, с другой.
Примеры:
=> \c mydb myuser host.dom 6432 => \c service=foo => \c "host=localhost port=5432 dbname=mydb connect_timeout=10 sslmode=disable" => \c -reuse-previous=on sslmode=require -- меняется только sslmode => \c postgresql://tom@localhost/mydb?application_name=myapp
\C [
заголовок
]Задаёт заголовок, который будет выводиться для результатов любых запросов или отменяет установленный ранее заголовок. Эта команда эквивалентна
\pset title
. (Название этой команды происходит от «caption» (заголовок), так как изначально она применялась только для задания заголовков HTML-таблиц.)заголовок
\cd [
каталог
]Сменяет текущий рабочий каталог на
каталог
. Без аргумента устанавливается домашний каталог текущего пользователя.Подсказка
для печати текущего рабочего каталога используйте
\! pwd
.\conninfo
Выводит информацию о текущем подключении к базе данных.
\copy {
таблица
[ (список_столбцов
) ] | (запрос
) } {from
|to
} {'имя_файла'
| program'команда'
| stdin | stdout | pstdin | pstdout } [ [ with ] (параметр
[, ...] ) ]Производит копирование данных с участием клиента. При этом выполняется SQL-команда COPY, но вместо чтения или записи в файл на сервере, psql читает или записывает файл и пересылает данные между сервером и локальной файловой системой. Это означает, что для доступа к файлам используются привилегии локального пользователя, а не сервера, и не требуются привилегии суперпользователя SQL.
С указанием
program
psql выполняеткоманду
и данные, поступающие из/в неё, передаются между сервером и клиентом. Это опять же означает, что для выполнения программ используются привилегии локального пользователя, а не сервера, и не требуются привилегии суперпользователя SQL.При выполнении
\copy ... from stdin
строки с данными считываются из источника, выполнившего команду, и считываются до тех пор, пока не встретится\.
или не будет достигнут конец файла. Этот параметр полезен для заполнения таблиц прямо в SQL-скриптах. При выполнении\copy ... to stdout
вывод направляется в то же место, что и вывод psql команд. Статус командыCOPY
не отображается, чтобы не перепутать со строкой данных. Для чтения/записи стандартного ввода/вывода psql, вне зависимости от источника текущей команды или параметраcount
\o
, используйтеfrom pstdin
илиto pstdout
.Синтаксис команды похож на синтаксис SQL-команды COPY. Все параметры, кроме источника и получателя данных, соответствуют параметрам COPY. Поэтому к команде
\copy
применяются специальные правила разбора. В частности, не применяются правила подстановки переменных и экранирование с обратной косой чертой.Подсказка
Альтернативный способ получить тот же результат, что и с
\copy ... to
— использовать SQL-командуCOPY ... TO STDOUT
и завершить её командой\g
илиимя
\g |
. В отличие отпрограмма
\copy
, этот подход позволяет разбивать команду на несколько строк, а также использовать интерполяцию переменных и раскрытие обратных кавычек (`
).Подсказка
Эти операции не так эффективны, как SQL-команда
COPY
, в которой источником или получателем данных является файл или программа, потому что все данные перемещаются между клиентом и сервером. Для больших объёмов данных SQL-команда может быть предпочтительнее.\copyright
Показывает информацию об авторских правах и условиях распространения Postgres Pro.
\crosstabview [
столбВ
[столбГ
[столбТ
[столбсортГ
] ] ] ]Выполняет содержимое буфера текущего запроса (как
\g
) и показывает результат в виде перекрёстной таблицы. Заданный запрос должен возвращать минимум три столбца. Столбец результата, заданный параметромстолбВ
, будет образовывать вертикальные заголовки, а столбец, заданный параметромстолбГ
, — горизонтальные. Заданный параметромстолбТ
столбец будет поставлять данные для отображения внутри таблицы. Столбец, выбранный параметромстолбсортГ
, будет необязательным столбцом сортировки горизонтальных заголовков.Каждое указание столбца может представлять собой имя или номер столбца (начиная с 1). К именам применяются обычные принятые в SQL правила учёта регистра и кавычек. По умолчанию в качестве
столбВ
подразумевается столбец 1, а в качествестолбГ
— столбец 2. ЕслистолбВ
истолбГ
задаются явно, они должны различаться. ЕслистолбТ
не задан, в результате запроса должно быть ровно три столбца, и в качествестолбТ
выбирается столбец, отличный отстолбВ
истолбГ
.Вертикальный заголовок, выводимый в самом левом столбце, содержит значения из столбца
столбВ
, в том же порядке, в каком их возвращает запрос, но без дубликатов.Горизонтальный заголовок, выводимый в первой строке, содержит значения из столбца
столбГ
, без дубликатов. По умолчанию они располагаются в том порядке, в каком их возвращает запрос. Но если задан необязательный аргументстолбсортГ
, он определяет столбец, который должен содержать целые числа, и тогда значения изстолбГ
будут располагаться в горизонтальном заголовке по порядку значений встолбсортГ
.Внутри перекрёстной таблицы для каждого уникального значения
x
встолбГ
и каждого уникального значенияy
встолбВ
, ячейка, размещённая на пересечении(x,y)
содержит значениестолбТ
в строке результата запроса, в которой значениестолбГ
равноx
, а значениестолбВ
—y
. Если такой строки не находится, ячейка остаётся пустой. Если же находится несколько таких строк, выдаётся ошибка.\d[S+] [
шаблон
]Для каждого отношения (таблицы, представления, материализованного представления, индекса, последовательности, внешней таблицы) или составного типа, соответствующих
шаблону
, показывает все столбцы, их типы, табличное пространство (если оно изменено) и любые специальные атрибуты, такие какNOT NULL
или значения по умолчанию. Также показываются связанные индексы, ограничения, правила и триггеры. Для сторонних таблиц также показывается связанный сторонний сервер. («Соответствие шаблону» определяется ниже в Шаблоны поиска.)Для некоторых типов отношений
\d
показывает дополнительную информацию по каждому столбцу: значения столбца для последовательностей, индексируемые выражения для индексов и параметры обёртки сторонних данных для сторонних таблиц.Вариант команды
\d+
похож на\d
, но выводит больше информации: комментарии к столбцам таблицы, наличие в таблице OID, для представления показывается его определение, отличные от значений по умолчанию установки replica identity.По умолчанию отображаются только объекты, созданные пользователем. Для включения системных объектов нужно задать шаблон или добавить модификатор
S
.Примечание
Если
\d
используется без аргументашаблон
, эта команда удобства ради воспринимается как\dtvmsE
и выдаёт список всех видимых таблиц, представлений, мат. представлений, последовательностей и сторонних таблиц.\da[S] [
шаблон
]Выводит список агрегатных функций вместе с типом возвращаемого значения и типами данных, которыми они оперируют. Если указан
шаблон
, показываются только те агрегатные функции, имена которых соответствуют ему. По умолчанию показываются только объекты, созданные пользователями. Для включения системных объектов нужно задать шаблон или добавить модификаторS
.\dA[+] [
шаблон
]Выводит список методов доступа. Если указан
шаблон
, показываются только те методы доступа, имена которых соответствуют ему. При добавлении+
к команде для каждого метода доступа показывается его описание и связанная функция-обработчик.\db[+] [
шаблон
]Выводит список табличных пространств. Если указан
шаблон
, показываются только те табличные пространства, имена которых соответствуют ему. При добавлении+
к команде для каждого объекта дополнительно выводятся параметры, объём на диске, права доступа и описание.\dc[S+] [
шаблон
]Выводит список преобразований между кодировками наборов символов. Если указан
шаблон
, показываются только те преобразования кодировок, имена которых соответствуют ему. По умолчанию показываются только объекты, созданные пользователями. Для включения системных объектов нужно задать шаблон или добавить модификаторS
. При добавлении+
к команде для каждого объекта дополнительно будет выводиться описание.\dC[+] [
шаблон
]Выводит список приведений типов. Если указан
шаблон
, показываются только те приведения типов, имена которых соответствуют ему. При добавлении+
к команде для каждого объекта дополнительно будет выводиться описание.\dd[S] [
шаблон
]Показывает описания объектов следующих видов:
ограничение
,класс операторов
,семейство операторов
,правило
итриггер
. Описания остальных объектов можно посмотреть соответствующими метакомандами для этих типов объектов.\dd
показывает описания для объектов, соответствующихшаблону
, или для доступных объектов указанных типов, если аргументы не заданы. Но в любом случае выводятся только те объекты, которые имеют описание. По умолчанию показываются только объекты, созданные пользователями. Для включения системных объектов нужно задать шаблон или добавить модификаторS
.Описания объектов создаются SQL-командой COMMENT.
\ddp [
шаблон
]Выводит список прав доступа по умолчанию. Выводится строка для каждой роли (и схемы, если применимо), для которой права доступа по умолчанию отличаются от встроенных. Если указан
шаблон
, выводятся строки только для тех ролей и схем, имена которых соответствуют ему.Права доступа по умолчанию устанавливаются командой ALTER DEFAULT PRIVILEGES. Смысл отображаемых прав объясняется в описании GRANT.
\dD[S+] [
шаблон
]Выводит список доменов. Если указан
шаблон
, показываются только те домены, имена которых соответствуют ему. По умолчанию показываются только объекты, созданные пользователями. Для включения системных объектов нужно задать шаблон или добавить модификаторS
. При добавлении+
к команде для каждого объекта дополнительно будут выводиться права доступа и описание.\dE[S+] [
шаблон
]\di[S+] [
шаблон
]\dm[S+] [
шаблон
]\ds[S+] [
шаблон
]\dt[S+] [
шаблон
]\dv[S+] [
шаблон
]В этой группе команд буквы
E
,i
,m
,s
,t
иv
обозначают соответственно: внешнюю таблицу, индекс, материализованное представление, последовательность, таблицу и представление. Можно указывать все или часть этих букв, в произвольном порядке, чтобы получить список объектов этих типов. Например,\dit
выводит список индексов и таблиц. При добавлении+
к команде для каждого объекта дополнительно будут выводиться физический размер на диске и описание, при наличии. Если указаншаблон
, выводятся только объекты, имена которых соответствуют ему. По умолчанию показываются только объекты, созданные пользователями. Для включения системных объектов нужно задать шаблон или добавить модификаторS
.\des[+] [
шаблон
]Выводит список сторонних серверов (мнемоника: «external servers»). Если указан
шаблон
, выводятся только те серверы, имена которых соответствуют ему. Если используется форма\des+
, то выводится полное описание каждого сервера, включая права доступа, тип, версию, параметры и описание.\det[+] [
шаблон
]Выводит список сторонних таблиц (мнемоника: «external tables»). Если указан
шаблон
, выводятся только те записи, имя таблицы или схемы которых соответствуют ему. Если используется форма\det+
, то дополнительно выводятся общие параметры и описание сторонней таблицы.\deu[+] [
шаблон
]Выводит список сопоставлений пользователей (мнемоника: «external users»). Если указан
шаблон
, выводятся только сопоставления, в которых имена пользователей соответствуют ему. Если используется форма\deu+
, то выводится дополнительная информация о каждом сопоставлении пользователей.Внимание
\deu+
также может отображать имя и пароль удалённого пользователя, поэтому следует позаботиться о том, чтобы не раскрывать их.\dew[+] [
шаблон
]Выводит список обёрток сторонних данных (мнемоника: «external wrappers»). Если указан
шаблон
, выводятся только те обёртки сторонних данных, имена которых соответствуют ему. Если используется форма\dew+
, то дополнительно выводятся права доступа, параметры и описание обёртки.\df[antwS+] [
шаблон
]Выводит список функций с типами данных их результатов, аргументов и классификацией: «agg» (агрегатная), «normal» (обычная), «trigger» (триггерная) или «window» (оконная). Чтобы получить функции только определённого вида (видов), добавьте в команду соответствующие буквы
a
,n
,t
илиw
. Если заданшаблон
, показываются только те функции, имена которых соответствуют ему. По умолчанию показываются только функции, созданные пользователями; для включения системных объектов нужно задать шаблон или добавить модификаторS
. Если используется форма\df+
, то дополнительно выводятся характеристики каждой функции: изменчивость, допустимость распараллеливания, владелец, классификация по безопасности, права доступа, язык, исходный код и описание.Подсказка
Чтобы найти функции с аргументами или возвращаемыми значениями определённого типа данных, воспользуйтесь имеющейся в постраничнике возможностью поиска в выводе
\df
.\dF[+] [
шаблон
]Выводит список конфигураций текстового поиска. Если указан
шаблон
, показываются только те конфигурации, имена которых соответствуют ему. Если используется форма\dF+
, то выводится полное описание для каждой конфигурации, включая базовый синтаксический анализатор и используемые словари для каждого типа фрагментов.\dFd[+] [
шаблон
]Выводит список словарей текстового поиска. Если указан
шаблон
, показываются только словари, имена которых соответствуют ему. Если используется форма\dFd+
, то выводится дополнительная информация о каждом словаре, включая базовый шаблон текстового поиска и параметры инициализации.\dFp[+] [
шаблон
]Выводит список анализаторов текстового поиска. Если указан
шаблон
, показываются только те анализаторы, имена которых соответствуют ему. Если используется форма\dFp+
, то выводится полное описание для каждого анализатора, включая базовые функции и список типов фрагментов.\dFt[+] [
шаблон
]Выводит список шаблонов текстового поиска. Если указан
шаблон
, показываются только шаблоны, имена которых соответствуют ему. Если используется форма\dFt+
, то выводится дополнительная информация о каждом шаблоне, включая имена основных функций.\dg[S+] [
шаблон
]Выводит список ролей базы данных. (Так как понятия «пользователи» и «группы» были объединены в «роли», эта команда теперь эквивалентна
\du
.) По умолчанию выводятся только роли, созданные пользователями: чтобы увидеть и системные роли, добавьте модификаторS
. Если указаншаблон
, выводятся только те роли, имена которых соответствуют ему. Если используется форма\dg+
, то выводится дополнительная информация о каждой роли; в настоящее время это комментарий роли.\dl
Это псевдоним для
\lo_list
, показывает список больших объектов.\dL[S+] [
шаблон
]Выводит список процедурных языков. Если указан
шаблон
, выводятся только те языки, имена которых соответствуют ему. По умолчанию показываются только языки, созданные пользователями. Для включения системных объектов нужно задать шаблон или добавить модификаторS
. При добавлении+
к команде для каждого языка дополнительно будут выводиться: обработчик вызова, функция проверки, права доступа и является ли язык системным объектом.\dn[S+] [
шаблон
]Выводит список схем (пространств имён). Если указан
шаблон
, выводятся только те схемы, имена которых соответствуют ему. По умолчанию показываются только объекты, созданные пользователями. Для включения системных объектов нужно задать шаблон или добавить модификаторS
. При добавлении+
к команде для каждого объекта дополнительно будут выводиться права доступа и описание, при наличии.\do[S+] [
шаблон
]Выводит список операторов, их операндов и типы результата. Если указан
шаблон
, выводятся только те операторы, имена которых соответствуют ему. По умолчанию показываются только объекты, созданные пользователями. Для включения системных объектов нужно задать шаблон или добавить модификаторS
. При добавлении+
к команде для каждого оператора будет выводиться дополнительная информация, сейчас это имя функции, на которой основан оператор.\dO[S+] [
шаблон
]Выводит список правил сортировки. Если указан
шаблон
, выводятся только те правила, имена которых соответствуют ему. По умолчанию показываются только объекты, созданные пользователями. Для включения системных объектов нужно задать шаблон или добавить модификаторS
. При добавлении+
к команде для каждого объекта дополнительно будет выводиться описание, при наличии. Обратите внимание, что отображаются только правила сортировки, применимые к кодировке текущей базы данных, поэтому результат команды может отличаться для различных баз данных этой же установки PostgreSQL.\dp [
шаблон
]Выводит список таблиц, представлений и последовательностей с их правами доступа. Если указан
шаблон
, отображаются только таблицы, представления и последовательности, имена которых соответствуют ему.Для установки прав доступа используются команды GRANT и REVOKE. Смысл отображаемых прав объясняется в описании GRANT.
\drds [
шаблон-ролей
[шаблон-баз
] ]Выводит список установленных параметров конфигурации. Эти параметры могут быть специфичными для роли, специфичными для базы данных, или обеих. Параметры
шаблон-ролей
ишаблон-баз
используются для отбора определённых ролей и баз данных, соответственно. Если они опущены, или указано*
, выводятся все параметры конфигурации, в том числе не относящиеся к ролям или базам данных.Команды ALTER ROLE и ALTER DATABASE используются для определения параметров конфигурации, специфичных для роли или базы данных.
\dT[S+] [
шаблон
]Выводит список типов данных. Если указан
шаблон
, выводятся только те типы, имена которых соответствуют ему. При добавлении+
к команде для каждого типа данных дополнительно будет выводиться: внутреннее имя типа, размер, допустимые значения для типаenum
и права доступа. По умолчанию показываются только объекты, созданные пользователями. Для включения системных объектов нужно задать шаблон или добавить модификаторS
.\du[S+] [
шаблон
]Выводит список ролей базы данных. (Так как понятия «пользователи» и «группы» были объединены в «роли», эта команда теперь равнозначна
\dg
.) По умолчанию выводятся только роли, созданные пользователями: чтобы увидеть и системные роли, добавьте модификаторS
. Если указаншаблон
, выводятся только те роли, имена которых соответствуют ему. Если используется форма\du+
, то выводится дополнительная информация о каждой роли; в настоящее время это комментарий роли.\dx[+] [
шаблон
]Выводит список установленных расширений. Если указан
шаблон
, выводятся только расширения, имена которых соответствуют ему. Если используется форма\dx+
, то для каждого расширения выводятся все принадлежащие ему объекты.\dy[+] [
шаблон
]Выводит список событийных триггеров. Если указан
шаблон
, выводятся только те событийные триггеры, имена которых соответствуют ему. При добавлении+
к команде для каждого объекта дополнительно будет выводиться описание.\e
или\edit
[
имя_файла
] [номер_строки
]Если указано
имя_файла
, файл открывается для редактирования. После выхода из редактора его содержимое копируется в буфер запроса. Если не указано имя файла, буфер текущего запроса копируется во временный файл и открывается в редакторе.Затем новый буфер запроса повторно анализируется согласно обычным правилам psql, при этом весь буфер рассматривается как одна строка. (Таким образом, это не подходит для создания скриптов. Для скриптов используйте
\i
.) Если запрос заканчивается (или содержит) точкой с запятой, он немедленно выполняется. В противном случае он просто будет ждать в буфере запроса. Введите точку с запятой или\g
для отправки на выполнение или\r
для отмены.Если указан номер строки, psql будет позиционировать курсор на указанную строку файла или буфера запроса. Обратите внимание, что если указан один аргумент и он числовой, psql предполагает, что это номер строки, а не имя файла.
Подсказка
Как настроить редактор и изменить его поведение, рассказывается в разделе Переменные окружения.
\echo
текст
[ ... ]Печатает аргументы в стандартный вывод, разделяя их одним пробелом и добавляя в конце перевод строки. Команда полезна для формирования вывода из скриптов. Например:
=>
\echo `date`
Tue Oct 26 21:40:57 CEST 1999Если первый аргумент
-n
без кавычек, то перевод строки в конце не ставится.Подсказка
Если используется команда
\o
для перенаправления вывода запросов, возможно, следует применять команду\qecho
вместо этой.\ef [
описание_функции
[номер_строки
]]Эта команда извлекает из базы данных определение заданной функции в форме
CREATE OR REPLACE FUNCTION
и отправляет его на редактирование. Редактирование осуществляется таким же образом, как и для\edit
. После выхода из редактора изменённая команда будет находиться в буфере запроса. Введите точку с запятой или\g
для выполнения или\r
для отмены.Для функции может быть задано только имя или имя и аргументы, например
foo(integer, text)
. Типы аргументов необходимы, если существует более чем одна функция с тем же именем.Если функция не указана, для редактирования открывается пустая заготовка
CREATE FUNCTION
.Если указан номер строки, psql будет позиционировать курсор на указанную строку тела функции. (Обратите внимание, что тело функции обычно не начинается на первой строке файла).
Подсказка
Как настроить редактор и изменить его поведение, рассказывается в разделе Переменные окружения.
\encoding [
кодировка
]Устанавливает кодировку набора символов на клиенте. Без аргумента команда показывает текущую кодировку.
\errverbose
Повторяет последнее серверное сообщение об ошибке с максимальным уровнем детализации, как если бы переменная
VERBOSITY
имела значениеverbose
, аSHOW_CONTEXT
—always
.\ev [
имя_представления
[номер_строки
]]Эта команда извлекает и открывает на редактирование определение указанного представления в форме команды
CREATE OR REPLACE VIEW
. Редактирование осуществляется так же, как и с\edit
. После выхода из редактора изменённая команда остаётся в буфере запроса; введите точку с запятой или\g
, чтобы выполнить её, либо\r
, чтобы её сбросить.Если представление не указано, для редактирования открывается пустая заготовка
CREATE VIEW
.Если указан номер строки, psql установит курсор на заданную строку в определении представления.
\f [
строка
]Устанавливает разделитель полей для невыровненного режима вывода запросов. По умолчанию используется вертикальная черта (
|
). См. также\pset
для универсального способа настройки параметров вывода.\g [
имя_файла
]\g [ |
команда
]Отправляет содержимое буфера текущего запроса на сервер для выполнения, с возможностью сохранения результата запроса в файле
имя_файла
или перенаправления вывода в команду оболочки ОСкоманда
. Вывод направляется в файл или команду, только если запрос успешно вернул 0 или более строк. Этого не происходит, если запрос завершился неудачно или выполнялась команда, не возвращающая данные.\g
без аргументов, по сути, эквивалентен точке с запятой.\g
с аргументом является разовой альтернативой команде\o
.\gexec
Отправляет буфер ввода текущего запроса на сервер, а затем обрабатывает содержимое каждого столбца каждой строки результата запроса (если он непустой) как SQL-оператор, то есть исполняет его. Например, следующая команда создаст индексы по каждому столбцу
my_table
:=>
SELECT format('create index on my_table(%I)', attname)
->FROM pg_attribute
->WHERE attrelid = 'my_table'::regclass AND attnum > 0
->ORDER BY attnum
->\gexec
CREATE INDEX CREATE INDEX CREATE INDEX CREATE INDEXГенерируемые запросы выполняются в том порядке, в каком возвращаются строки, слева направо, если возвращается несколько столбцов. Поля NULL игнорируются. Эти запросы передаются для обработки на сервер буквально, так что это не могут быть метакоманды psql или запросы, использующие переменные psql. В случае сбоя в одном из запросов, выполнение оставшихся запросов продолжается, если только не установлена переменная
ON_ERROR_STOP
. На выполнение каждого запроса оказывает влияние параметрECHO
. (Применяя команду\gexec
, рекомендуется устанавливать вECHO
режимall
илиqueries
.) Такие расширенные средства, как протоколирование запросов, пошаговый режим, замер времени и т. п., так же действуют при выполнении каждого генерируемого запроса.\gset [
префикс
]Отправляет буфер текущего запроса на сервер для выполнения и сохраняет результат запроса в переменных psql (см. раздел Переменные). Выполняемый запрос должен возвращать ровно одну строку. Каждый столбец строки результата сохраняется в отдельной переменной, которая называется так же, как и столбец. Например:
=>
SELECT 'hello' AS var1, 10 AS var2
->\gset
=>\echo :var1 :var2
hello 10Если указан
префикс
, то он добавляется в начале к именам переменных:=>
SELECT 'hello' AS var1, 10 AS var2
->\gset result_
=>\echo :result_var1 :result_var2
hello 10Если значение столбца NULL, то вместо присвоения значения соответствующая переменная удаляется.
Если запрос завершается ошибкой или не возвращает одну строку, то никакие переменные не меняются.
\h
или\help
[
команда
]Выводит подсказку по синтаксису указанной команды SQL. Если
команда
не указана, то psql выводит список всех команд, для которых доступна справка. Если в качестве command указана звёздочка (*
), то выводится справка по всем командам SQL.Примечание
Для упрощения ввода команды, состоящие из нескольких слов, можно не заключать в кавычки. Таким образом, можно просто писать
\help alter table
.\H
или\html
Включает вывод запросов в формате HTML. Если формат HTML уже включён, происходит переключение обратно на выровненный формат. Эта команда используется для совместимости и удобства, но в описании
\pset
вы можете узнать о других вариантах вывода.\i
или\include
имя_файла
Читает ввод из файла
имя_файла
и выполняет его, как будто он был набран на клавиатуре.Если
имя_файла
задано как-
(минус), читается стандартный ввод до признака конца файла или до метакоманды\q
. Это может быть полезно для совмещения интерактивного ввода со вводом команд из файлов. Заметьте, что при этом поведение Readline будет применяться, только если оно активно на внешнем уровне.Примечание
Если вы хотите видеть строки файла на экране по мере их чтения, необходимо установить для переменной
ECHO
значениеall
.\ir
или\include_relative
имя_файла
Команда
\ir
похожа на\i
, но по-разному интерпретирует относительные имена файлов. При выполнении в интерактивном режиме две команды ведут себя одинаково. Однако при вызове из скрипта\ir
интерпретирует имена файлов относительно каталога, в котором расположен скрипт, а не текущего рабочего каталога.\l[+]
или\list[+] [
шаблон
]Выводит список баз данных на сервере и показывает их имена, владельцев, кодировку набора символов и права доступа. Если указан
шаблон
, выводятся только базы данных, имена которых соответствуют ему. При добавлении+
к команде также отображаются: размер базы данных, табличное пространство по умолчанию и описание. (Информация о размере доступна только для баз данных, к которым текущий пользователь может подключиться.)\lo_export
oid_БО
имя_файла
Читает большой объект с заданным
oid_БО
из базы данных и записывает его в файлимя_файла
. Обратите внимание, что это несколько отличается от серверной функцииlo_export
, действующей с правами пользователя, от имени которого работает сервер базы данных, и в файловой системе сервера.Подсказка
Используйте
\lo_list
для получения OID больших объектов.\lo_import
имя_файла
[комментарий
]Сохраняет файл в большом объекте Postgres Pro. При этом с объектом может быть связан указанный комментарий. Пример:
foo=>
\lo_import '/home/peter/pictures/photo.xcf' 'a picture of me'
lo_import 152801Ответ указывает на то, что большой объект получил OID 152801, который может быть использован для доступа к вновь созданному объекту в будущем. Для удобства чтения рекомендуется всегда связывать объекты с понятными комментариями. OID и комментарии можно посмотреть с помощью команды
\lo_list
.Обратите внимание, что это немного отличается от функции сервера
lo_import
, так как действует от имени локального пользователя в локальной файловой системе, а не пользователя сервера в файловой системе сервера.\lo_list
Показывает список всех больших объектов Postgres Pro, хранящихся в базе данных, вместе с предоставленными комментариями.
\lo_unlink
oid_БО
Удаляет большой объект с
oid_БО
из базы данных.Подсказка
Используйте
\lo_list
для получения OID больших объектов.\o
или\out [
имя_файла
]\o
или\out [ |
команда
]Результаты запросов будут сохраняться в файле
имя_файла
или перенаправляться команде оболочки (заданной аргументомкоманда
). Если аргумент не указан, результаты запросов перенаправляются на стандартный вывод.«Результаты запросов» включают в себя все таблицы, ответы команд, уведомления, полученные от сервера базы данных, а также вывод от метакоманд, запрашивающих базу данных (таких как
\d
), но не сообщения об ошибках.Подсказка
Чтобы вставить текст между результатами запросов, используйте
\qecho
.\p
или\print
Печатает содержимое буфера текущего запроса в стандартный вывод.
\password [
имя_пользователя
]Изменяет пароль указанного пользователя (по умолчанию, текущего пользователя). Эта команда запрашивает новый пароль, шифрует и отправляет его на сервер в виде команды
ALTER ROLE
. Это гарантирует, что новый пароль не отображается в открытом виде в истории команд, журнале сервера или в другом месте.\prompt [
текст
]имя
Предлагает пользователю ввести значение, которое будет присвоено переменной
имя
. Дополнительно можно указатьтекст
подсказки. (Если подсказка состоит из нескольких слов, то её текст нужно взять в одинарные кавычки).По умолчанию,
\prompt
использует терминал для ввода и вывода. Однако если используется параметр командной строки-f
,\prompt
использует стандартный ввод и стандартный вывод.\pset [
параметр
[значение
] ]Эта команда устанавливает параметры, влияющие на вывод результатов запросов. Указание
параметр
определяет, какой параметр требуется установить. Семантиказначения
зависит от выбранного параметра. Для некоторых параметров отсутствиезначения
означает переключение значения, либо сброс значения, как описано ниже в разделе конкретного параметра. Если такое поведение не упоминается, то пропускзначения
приводит к отображению текущего значения параметра.\pset
без аргументов выводит текущий статус всех параметров команды.Имеются следующие параметры:
border
Здесь
значение
должно быть числом. В целом, чем больше это число, тем больше границ и линий будет в таблицах, но детали зависят от формата. В формате HTML заданное значение напрямую отображается в атрибутborder=...
. Для большинства других форматов имеют смысл только значения 0 (нет границы), 1 (внутренние разделительные линии) и 2 (граница таблицы), а значения больше 2 воспринимаются какborder = 2
. Форматыlatex
иlatex-longtable
дополнительно поддерживают значение 3, добавляющее разделительные линии между строками данных.columns
Устанавливает максимальную ширину для формата
wrapped
, а также ограничение по ширине, свыше которого будет требоваться постраничник или произойдёт переключение в вертикальное отображение при режимеexpanded auto
. При значении 0 (по умолчанию) максимальная ширина управляется переменной средыCOLUMNS
или шириной экрана, еслиCOLUMNS
не установлена. Кроме того, еслиcolumns
равно нулю, то форматwrapped
влияет только на вывод на экран. Еслиcolumns
не равно 0, то это также влияет на вывод в файл или в другую команду через канал.expanded
(илиx
)Указанное
значение
допускает вариантыon
илиoff
, которые включают или отключают развёрнутый режим, либоauto
. Еслизначение
опущено, команда включает/отключает режим. Когда развёрнутый режим включён, результаты запроса выводятся в две колонки: имя столбца в левой, данные в правой. Этот режим полезен, если данные не помещаются на экране в обычном «горизонтальном» режиме. При выбореauto
развёрнутый режим используется, когда результат запроса содержит несколько столбцов и по ширине не умещается на экране; в противном случае используется обычный режим. Режимauto
распространяется только на форматыaligned
иwrapped
. С другими форматами он всегда равнозначен отключённому состоянию.fieldsep
Устанавливает разделитель полей для невыровненного режима вывода запросов. Таким образом, можно формировать вывод, в котором значения будут разделены табуляцией или запятыми. Это может быть предпочтительным для использования в других программах. Для установки символа табуляции в качестве разделителя полей введите
\pset fieldsep '\t'
. По умолчанию используется вертикальная черта ('|'
).fieldsep_zero
Устанавливает разделитель полей для невыровненного режима вывода в нулевой байт.
footer
Возможны два варианта
значения
:on
илиoff
, которые включают или отключают вывод результирующей строки с количеством выбранных записей(
. Еслиn
строк)значение
не указано, то команда переключает текущее значение вon
илиoff
.format
Устанавливает один из следующих форматов вывода:
unaligned
,aligned
,wrapped
,html
,asciidoc
,latex
(используетtabular
),latex-longtable
илиtroff-ms
. Допускается сокращение слова до уникального значения.В формате
unaligned
все столбцы размещаются на одной строке и отделяются друг от друга текущим разделителем полей. Это полезно для создания вывода, который будут читать другие программы (например, для вывода данных с разделителем Tab или через запятую).Формат
aligned
это стандартный, удобочитаемый, хорошо отформатированный текстовый вывод. Используется по умолчанию.Формат
wrapped
похож наaligned
, но переносит длинные значения столбцов на новые строки, чтобы общий вывод поместился в заданную ширину. Задание ширины вывода описано в параметреcolumns
. Обратите внимание, что psql не будет пытаться переносить на новые строки заголовки столбцов. Поэтому форматwrapped
работает так же, какaligned
если общая ширина, требуемая для всех заголовков столбцов, превышает установленную максимальную ширину.Форматы
html
,asciidoc
,latex
,latex-longtable
иtroff-ms
выводят таблицы, которые предназначены для включения в документы с помощью соответствующего языка разметки. Они не являются полноценными документами! Это может быть не критично для HTML, но для LaTeX обязателен документ-контейнер. Форматlatex-longtable
также требует наличия пакетов LaTeXlongtable
иbooktabs
.linestyle
Задаёт стиль отрисовки линий границы:
ascii
,old-ascii
илиunicode
. Допускается сокращение слова до уникального значения. (Это значит, что одной буквы будет достаточно.) Значение по умолчанию:ascii
. Этот параметр действует только в форматахaligned
иwrapped
.Стиль
ascii
использует обычные символы ASCII. Символы новой строки в данных показываются с использованием символа+
в правом поле. Когда при форматеwrapped
происходит перенос данных на новую строку (без символа новой строки), ставится точка (.
) в правом поле первой строки и точка в левом поле следующей строки.Стиль
old-ascii
использует обычные символы ASCII в стиле PostgreSQL 8.4 и раньше. Символы новой строки в данных отображаются, используя символ:
вместо левого разделителя полей. Когда происходит перенос данных на новую строку без символа новой строки, символ;
используется вместо левого разделителя полей.Стиль
unicode
использует символы Юникода для рисования линий. Символы новой строки в данных показываются с использованием символа возврата каретки в правом поле. Когда при форматеwrapped
происходит перенос данных на новую строку (без символа новой строки), ставится символ многоточия в правом поле первой строки и в левом поле следующей строки.Когда значение
border
больше нуля, параметрlinestyle
также определяет символы, которыми будут рисоваться границы. Обычные символы ASCII работают везде, но символы Юникода смотрятся лучше на терминалах, распознающих их.null
Устанавливает строку, которая будет напечатана вместо значения null. По умолчанию не печатается ничего, что можно ошибочно принять за пустую строку. Например, можно было бы предпочесть
\pset null '(null)'
.numericlocale
Если задаётся
значение
, возможны два варианта:on
илиoff
, которые включают или отключают отображение специфичного для локали символа, разделяющего группы цифр левее десятичной точки. Еслизначение
не указано, то команда переключает вывод чисел с локализованного на обычный и обратно.pager
Управляет использованием постраничника для просмотра результатов запросов и справочной информации psql. Если переменная среды
PAGER
установлена, то данные передаются в указанную программу. В противном случае используется платформозависимая программа по умолчанию (например,more
).Если
pager
имеет значениеoff
, программа постраничного просмотра (постраничник) не используется. Еслиpager
имеет значениеon
, эта программа используется при необходимости, т. е. когда вывод на терминал не помещается на экране. Параметр pager также может иметь значениеalways
, при этом постраничник будет использоваться всегда, независимо от того, помещается вывод на экран терминала или нет. Команда\pset pager
без указаниязначения
переключает вариантыon
иoff
.pager_min_lines
Если в
pager_min_lines
задаётся число, превышающее высоту страницы, программа постраничного вывода не будет вызываться, пока не наберётся заданное число строк для вывода. Значение по умолчанию — 0.recordsep
Устанавливает разделитель записей (строк) для невыровненного режима вывода. По умолчанию используется символ новой строки.
recordsep_zero
Устанавливает разделитель записей для невыровненного режима вывода в нулевой байт.
tableattr
(илиT
)Устанавливает атрибуты, которые будут помещены в тег
table
, при формате вывода HTML. Например, это может бытьcellpadding
илиborder
. Заметьте, что, вероятно, не нужно здесь задаватьborder
, так как для этого уже есть\pset border
. Еслизначение
не задано, атрибуты таблицы удаляются.В формате
latex-longtable
этот параметр контролирует пропорциональную ширину каждого столбца, данные которого выровнены по левому краю. Он указывается как список разделённых пробелами значений, например'0.2 0.2 0.6'
. Для столбцов, которым не хватает значений, используется последнее из заданных.title
(илиC
)Устанавливает заголовок таблицы для любых впоследствии выводимых таблиц. Это можно использовать для задания описательных тегов при формировании вывода. Если
значение
не задано, заголовок таблицы удаляется.tuples_only
(илиt
)Возможны два варианта
значения
:on
илиoff
, которые включают или отключают режим вывода только кортежей. Еслизначение
не указано, то команда переключает с режима вывода только кортежей на обычный режим и обратно. Обычный вывод включает в себя дополнительную информацию, такую как заголовки столбцов и различные колонтитулы. В режиме вывода только кортежей отображаются только фактические табличные данные.unicode_border_linestyle
Устанавливает стиль рисования границ для стиля линий
unicode
:single
(одинарный) илиdouble
(двойной).unicode_column_linestyle
Устанавливает стиль рисования колонок для стиля линий
unicode
:single
(одинарный) илиdouble
(двойной).unicode_header_linestyle
Устанавливает стиль рисования заголовка для стиля линий
unicode
:single
(одинарный) илиdouble
(двойной).
Иллюстрацию того, как могут выглядеть различные форматы, можно увидеть в разделе Примеры.
Подсказка
Для некоторых параметров
\pset
есть короткие команды. См.\a
,\C
,\f
,\H
,\t
,\T
и\x
.\q
или\quit
Выход из psql. При использовании в скрипте прекращается только выполнение этого скрипта.
\qecho
текст
[ ... ]Эта команда идентична
\echo
за исключением того, что вывод будет записываться в канал вывода запросов, установленный\o
.\r
или\reset
Сбрасывает (очищает) буфер запроса.
\s [
имя_файла
]Записывает историю команд psql в файл
имя_файла
. Еслиимя_файла
не указано, история команд выводится в стандартный вывод (с использованием постраничника, когда уместно). Этот параметр недоступен, если psql был собран без поддержки Readline.\set [
имя
[значение
[ ... ] ] ]Задаёт psql переменной
имя
значение
или, если задано более одного значения, их конкатенацию. Если задан только один аргумент, то переменной с этим именем присваивается пустое значение. Для удаления переменной используйте команду\unset
.\set
без аргументов выводит имена и значения всех psql переменных, установленных в настоящее время.Имена переменных могут содержать буквы, цифры и знаки подчёркивания. Подробнее см. раздел Переменные ниже. Имена переменных чувствительны к регистру.
Хотя вы можете задать любой переменной любое значение, psql рассматривает несколько переменных особым образом. Они документированы в разделе о переменных.
Примечание
Эта команда не имеет отношения к SQL-команде SET.
\setenv
имя
[значение
]Задаёт для переменной среды
имя
значение
или, еслизначение
не задано, удаляет переменную среды. Пример:testdb=>
\setenv PAGER less
testdb=>\setenv LESS -imx4F
\sf[+]
описание_функции
Извлекает из базы данных и выводит определение заданной функции в форме команды
CREATE OR REPLACE FUNCTION
. Определение печатается в текущий канал вывода запросов, установленный\o
.Для функции может быть задано только имя или имя и аргументы, например
foo(integer, text)
. Типы аргументов необходимы, если существует более чем одна функция с тем же именем.При добавлении
+
к команде строки вывода нумеруются, первая строка тела функции получит номер 1.\sv[+]
имя_представления
Извлекает из базы данных и выводит определение указанного представления в форме команды
CREATE OR REPLACE VIEW
. Определение выводится в текущий канал вывода запросов, установленный\o
.При добавлении
+
к команде строки вывода нумеруются, начиная с 1.\t
Включает/выключает отображение имён столбцов и результирующей строки с количеством выбранных записей для запросов. Эта команда эквивалентна
\pset tuples_only
и предоставлена для удобства.\T
параметры_таблицы
Устанавливает атрибуты, которые будут помещены в тег
table
при формате вывода HTML. Эта команда эквивалентна\pset tableattr
.параметры_таблицы
\timing [
on
|off
]Включает/отключает отображение времени выполнения команд SQL в миллисекундах. Без параметра переключает текущий режим отображения времени выполнения.
\unset
имя
Удаляет psql переменную
имя
.\w
или\write
имя_файла
\w
или\write
|
команда
Выводит буфер текущего запроса в файл
имя_файла
или передаёт в команду ОСкоманда
.\watch [
секунды
]Эта команда многократно выполняет текущий запрос в буфере (как
\g
), пока не будет прервана или не возникнет ошибка. Аргумент задаёт количество секунд ожидания между выполнениями запроса (по умолчанию 2). Результат каждого запроса выводится с заголовком, включающим строку\pset title
(если она задана), время запуска запроса и интервал задержки.\x [
on
|off
|auto
]Устанавливает или переключает режим развёрнутого вывода таблицы. Это эквивалентно
\pset expanded
.\z [
шаблон
]Выводит список таблиц, представлений и последовательностей с их правами доступа. Если указан
шаблон
, отображаются только таблицы, представления и последовательности, имена которых соответствуют ему.Это псевдоним для
\dp
(«показать права доступа»).\! [
команда
]Выполняет
команду
ОС. Без указаниякоманды
запускает отдельную командную оболочку ОС. Последующие аргументы не интерпретируются, командная оболочка ОС увидит их как есть. В частности, не применяются правила подстановки переменных и экранирование с обратной косой чертой.\? [
тема
]Показывает справочную информацию. Необязательный параметр
тема
(по умолчаниюcommands
) выбирает описание интересующей части psql:commands
описывает команды psql с обратной косой чертой;options
описывает параметры командной строки, которые можно передать psql; аvariables
выдаёт справку по переменным конфигурации psql.
Шаблоны поиска
Различные \d
команды принимают параметр шаблон
для указания имени (имён) объектов для отображения. В простейшем случае шаблон — это точное имя объекта. Символы внутри шаблона обычно приводятся к нижнему регистру, как и для имён SQL-объектов; к примеру \dt FOO
выводит таблицу с именем foo
. Как и для SQL имён, двойные кавычки вокруг шаблона предотвращают перевод в нижний регистр. Для включения символа двойной кавычки в шаблон используются два символа двойных кавычек подряд внутри шаблона в двойных кавычках. Опять же, это соответствует правилам для SQL-идентификаторов. Например \dt "FOO""BAR"
будет выводить таблицу с именем FOO"BAR
(но не foo"bar
). В отличие от обычных правил для SQL-имён, можно взять в двойные кавычки только часть шаблона, например \dt FOO"FOO"BAR
будет выводить таблицу с именем fooFOObar
.
Если шаблон
вообще не указан, команды \d
выводят все объекты, видимые с текущим путём поиска схем. Это эквивалентно указанию *
в качестве шаблона. (Объект считается видимым, если схема, к которой он относится, находится в пути поиска, и объект с таким же типом и именем в пути поиска ещё не встречался. Это эквивалентно утверждению, что на объект можно ссылаться по имени, без явного указания схемы.) Чтобы увидеть все объекты в базе данных, независимо от видимости, используйте в качестве шаблона *.*
.
Внутри шаблона *
обозначает любое количество символов, включая отсутствие символов. ?
соответствует любому одному символу. (Это соответствует шаблонам имён файлов в Unix.) Например, \dt int*
отображает все таблицы, имена которых начинаются на int
. Однако внутри двойных кавычек *
и ?
теряют своё специальное значение и становятся обычными символами.
Шаблон, содержащий точку (.
), интерпретируется как шаблон имени схемы, за которым следует шаблон имени объекта. Например, \dt foo*.*bar*
отображает все таблицы, имена которых включают bar
, и расположенные в схемах, имена которых начинаются с foo
. Шаблону, не содержащему точку, могут соответствовать только объекты текущей схемы. Опять же, точка внутри двойных кавычек теряет своё специальное значение.
Опытные пользователи могут использовать возможности регулярных выражений, такие как классы символов. Например [0-9]
соответствует любой цифре. Все специальные символы регулярных выражений работают как описано в Подразделе 9.7.3, за исключением: .
используется в качестве разделителя, как говорилось выше; *
соответствует регулярному выражению .*
; ?
соответствует .
, а также символ $
, который не имеет специального значения. При необходимости эти символы можно эмулировать указывая ?
для эмуляции .
, (
для R
+|)
, R
*(
для R
|)
. R
?$
не требуется, как символ регулярного выражения, потому что шаблон должен соответствовать имени целиком, в отличие от обычной интерпретации регулярных выражений (другими словами, $
автоматически добавляется в шаблон). Используйте *
в начале и/или в конце, если не хотите, чтобы шаблон закреплялся. Обратите внимание, что внутри двойных кавычек, все специальные символы регулярных выражений теряют своё специальное значение и соответствуют сами себе. Также, специальные символы регулярных выражений не действуют в шаблонах для имён операторов (т. е. в аргументе команды \do
).
Расширенные возможности
Переменные
psql предоставляет возможности подстановки переменных подобные тем, что используются в командных оболочках Unix. Переменные представляют собой пары имя/значение, где значением может быть любая строка любой длины. Имя должно состоять из букв (включая нелатинские буквы), цифр и знаков подчёркивания.
Чтобы установить переменную, используется метакоманда psql \set
. Например:
testdb=> \set foo bar
присваивает переменной foo
значение bar
. Чтобы получить значение переменной, нужно поставить двоеточие перед её именем, например:
testdb=> \echo :foo
bar
Это работает как в обычных SQL-командах, так и в метакомандах; подробности в разделе Интерполяция SQL ниже.
При вызове \set
без второго аргумента переменной присваивается пустая строка. Для удаления переменной используется команда \unset
. Чтобы посмотреть значения всех переменных, нужно вызвать \set
без аргументов.
Примечание
На аргументы \set
распространяются те же правила подстановки, что и для других команд. Таким образом можно создавать интересные ссылки, например \set :foo 'something'
, получая «мягкие ссылки» в Perl или «переменные переменных» в PHP. К сожалению (или к счастью?), с этими конструкциями нельзя сделать ничего полезного. С другой стороны, \set bar :foo
является прекрасным способом копирования переменной.
Некоторые переменные обрабатываются в psql особым образом. Они представляют собой определённые параметры, которые могут быть изменены во время выполнения путём присваивания нового значения, а в некоторых переменных содержится изменяемое состояние psql. Хотя эти переменные можно использовать и для других целей, делать это не рекомендуется, так как поведение программы может быстро стать очень странным. По соглашению, имена специальных переменных состоят из всех заглавных ASCII букв (и, возможно, цифр и знаков подчёркивания). Для максимальной совместимости в будущем старайтесь не использовать такие имена для собственных переменных. Далее идет список переменных, обрабатываемых особым образом.
-
AUTOCOMMIT
При значении
on
(по умолчанию) после каждой успешно выполненной команды выполняется фиксация изменений. Чтобы отложить фиксацию изменений в этом режиме, нужно выполнить SQL-командуBEGIN
илиSTART TRANSACTION
. При значенииoff
или если переменная не определена, фиксация изменений не происходит до тех пор, пока явно не выполнена командаCOMMIT
илиEND
. При значенииoff
неявно выполняетсяBEGIN
непосредственно перед любой командой, за исключением случаев когда: команда уже в транзакционном блоке; перед самой командойBEGIN
или другой командой управления транзакциями; перед командой, которая не может выполняться внутри транзакционного блока (напримерVACUUM
).Примечание
Если режим
autocommit
отключён, необходимо явно откатывать изменения в неуспешных транзакциях, выполняя командуABORT
илиROLLBACK
. Также имейте в виду, что при выходе из сессии без фиксации изменений несохранённые изменения будут потеряны.Примечание
Включённый режим
autocommit
является традиционным для Postgres Pro, а выключенный режим ближе к спецификации SQL. Если вы предпочитаете отключить режимautocommit
, это можно сделать в общесистемном файлеpsqlrc
или в персональном файле~/.psqlrc
.COMP_KEYWORD_CASE
Определяет, какой регистр букв будет использован при автоматическом завершении ключевых слов SQL. Если установлено в
lower
илиupper
, будет использоваться нижний или верхний регистр соответственно. Если установлено вpreserve-lower
илиpreserve-upper
(по умолчанию), то завершаемое слово будет в том же регистре, что и уже введённое начало слова, но последующие слова, завершаемые полностью, будут в нижнем или верхнем регистре соответственно.DBNAME
Имя базы данных, к которой вы сейчас подключены. Устанавливается всякий раз при подключении к базе данных (в том числе при старте программы), но эту переменную можно удалить.
ECHO
Со значением
all
все непустые входящие строки печатаются в стандартный вывод по мере их чтения. (Это не относится к строкам, считываемым интерактивно.) Чтобы выбрать такое поведение при запуске программы, добавьте ключ-a
. Со значениемqueries
, psql печатает каждый запрос, отправленный серверу, в стандартный вывод. Этому значению соответствует ключ-e
. Со значениемerrors
в стандартный канал ошибок выдаются только запросы, вызвавшие ошибки. Ему соответствует ключ-b
. В случае отсутствия значения и с вариантомnone
(либо другим вариантом, кроме перечисленных) запросы не выводятся.ECHO_HIDDEN
Если эта переменная установлена в значение
on
, то при выполнении метакоманд, запрашивающих базу данных, сначала будет выводиться текст запроса. Это позволяет изучать внутреннее устройство Postgres Pro и реализовывать похожую функциональность в своих программах. (Чтобы включить такое поведение при старте psql, используйте параметр-E
.) При установке переменной в значениеnoexec
запросы просто отображаются, но не отправляются на сервер и не выполняются.ENCODING
Содержит текущую кодировку набора символов клиента.
FETCH_COUNT
Если переменная установлена в целое значение > 0, результаты запросов
SELECT
извлекаются из базы данных и отображаются группами с таким количеством строк, в отличие от поведения по умолчанию, когда перед отображением результирующий набор накапливается целиком. Это позволяет использовать ограниченный размер памяти независимо от размера выборки. При включении этой функциональности обычно используются значения от 100 до 1000. Имейте в виду, что запрос может завершиться ошибкой после отображения некоторого количества строк.Подсказка
Хотя можно использовать любой формат вывода, формат по умолчанию
aligned
как правило выглядит хуже, потому что каждая группа поFETCH_COUNT
строк форматируется отдельно, что может привести к разной ширине столбцов в разных группах. Остальные форматы вывода работают лучше.HISTCONTROL
Если переменная имеет значение
ignorespace
, строки, начинающиеся с пробела, не сохраняются в истории. Если она имеет значениеignoredups
, в историю не добавляются строки, которые в ней уже есть. Значениеignoreboth
объединяет эти два варианта. В случае отсутствия значения и с вариантомnone
(либо другим вариантом, кроме перечисленных) в истории сохраняются все строки, считываемые в интерактивном режиме.Примечание
Эта функциональность была бессовестно списана с Bash.
HISTFILE
Имя файла для хранения истории команд. Значение по умолчанию
~/.psql_history
. Например, установив:\set HISTFILE ~/.psql_history- :DBNAME
в
~/.psqlrc
, psql будет поддерживать отдельную историю для каждой базы данных.Примечание
Эта функциональность была бессовестно списана с Bash.
HISTSIZE
Количество команд для хранения в истории. Значение по умолчанию 500.
Примечание
Эта функциональность была бессовестно списана с Bash.
HOST
Имя компьютера, где работает сервер базы данных, к которому вы сейчас подключены. Устанавливается всякий раз при подключении к базе данных (в том числе при старте программы), но эту переменную можно удалить.
IGNOREEOF
Если не установлена, символ конца файла (EOF, обычно Control+D), переданный в интерактивном сеансе psql, завершит приложение. Если задано числовое значение, то именно такое количество символов EOF будет проигнорировано, прежде чем приложение завершит работу. Если переменная установлена, но имеет не числовое значение, подразумевается 10.
Примечание
Эта функциональность была бессовестно списана с Bash.
LASTOID
Содержит значение последнего OID, полученного командой
INSERT
или\lo_import
. Корректное значение переменной гарантируется до тех пор, пока не будет отображён результат следующей SQL-команды.-
ON_ERROR_ROLLBACK
При значении
on
, если команда в транзакционном блоке выдаёт ошибку, ошибка игнорируется и транзакция продолжается. При значенииinteractive
такие ошибки игнорируются только в интерактивных сессиях, но не в скриптах. Если переменная не установлена или при значенииoff
команда, вызвавшая ошибку в транзакционном блоке, отменяет всю транзакцию. Режим отката транзакции при возникновении ошибки обеспечивается выполнением неявных командSAVEPOINT
перед каждой командой в транзакционном блоке и откатом к точке сохранения в случае ошибки.ON_ERROR_STOP
По умолчанию, после возникновения ошибки обработка команд продолжается. Если эта переменная установлена в значение
on
, обработка команд будет немедленно прекращена. В интерактивном режиме psql вернётся в командную строку; иначе psql прекратит работу с кодом возврата 3, чтобы отличить этот случай от фатальных ошибок, для которых используется код возврата 1. В любом случае выполнение всех запущенных скриптов (высокоуровневый скрипт и любые другие, которые он мог запустить) будет немедленно прекращено. Если высокоуровневая командная строка содержит несколько SQL-команд, выполнение завершится на текущей команде.PORT
Содержит порт сервера базы данных, к которому вы сейчас подключены. Устанавливается всякий раз при подключении к базе данных (в том числе при старте программы), но эту переменную можно удалить.
PROMPT1
PROMPT2
PROMPT3
Указывают, как должны выглядеть приглашения psql. См. Настройка приглашений.
QUIET
Установка значения
on
эквивалента параметру командной строки-q
. Это, вероятно, не слишком полезно в интерактивном режиме.SHOW_CONTEXT
Этой переменной можно присвоить значения
never
(никогда),errors
(ошибки) илиalways
(всегда), определяющие, когда в сообщениях с сервера будут выводиться поляКОНТЕКСТ
. По умолчанию выбран вариантerrors
(который означает, что контекст будет выводиться в сообщениях об ошибках, но не в предупреждениях и уведомлениях). Этот параметр не действует, когда установлен уровеньVERBOSITY
terse
. (Когда вам потребуется подробная версия только что выданной ошибки, может быть полезна команда\errverbose
.)SINGLELINE
Установка значения
on
эквивалентна параметру командной строки-S
.SINGLESTEP
Эта переменная эквивалентна параметру командной строки
-s
.USER
Содержит имя пользователя базы данных, который сейчас подключён. Устанавливается всякий раз при подключении к базе данных (в том числе при старте программы), но эту переменную можно удалить.
VERBOSITY
Этой переменной можно присвоить значения
default
,verbose
илиterse
для изменения уровня детализации в сообщениях об ошибках. (См. также команду\errverbose
, полезную, когда требуется подробная версия только что выданной ошибки.)
Интерполяция SQL
Ключевой особенностью переменных psql является возможность подставлять («интерполировать») их в команды SQL, так же как и в аргументы метакоманд. Кроме того, psql предоставляет средства для корректного использования кавычек для значений переменных, которые используются как литералы или идентификаторы SQL. Чтобы подставить значение без кавычек, нужно добавить перед именем переменной двоеточие (:
). Например:
testdb=>\set foo 'my_table'
testdb=>SELECT * FROM :foo;
будет запрашивать таблицу my_table
. Обратите внимание, что это может быть небезопасным: значение переменной копируется буквально, поэтому оно может содержать непарные кавычки или даже метакоманды. При применении необходимо убедиться, что это имеет смысл.
Когда значение будет использоваться в качестве SQL литерала или идентификатора, безопаснее заключить его в кавычки. Если значение переменной используется как SQL литерал, то после двоеточия нужно написать имя переменной в одинарных кавычках. Если значение переменной используется как SQL идентификатор, то после двоеточия нужно написать имя переменной в двойных кавычках. Эти конструкции корректно работают с кавычками и другими специальными символами, которые могут содержаться в значении переменной. Предыдущий пример более безопасно выглядит так:
testdb=>\set foo 'my_table'
testdb=>SELECT * FROM :"foo";
Подстановка переменных не будет выполняться, если SQL литералы или идентификаторы заключены в кавычки. Поэтому конструкция ':foo'
не превратится во взятое в кавычки значение переменной (и это было бы небезопасно, если бы работало, так как обработка кавычек внутри значения переменной была бы некорректной).
Один из примеров использования данного механизма — это копирование содержимого файла в столбец таблицы. Сначала загрузим содержимое файла в переменную, затем подставим значение переменной как строку в кавычках:
testdb=>\set content `cat my_file.txt`
testdb=>INSERT INTO my_table VALUES (:'content');
(Отметим, что это пока не будет работать, если my_file.txt
содержит байт NUL. psql не поддерживает NUL в значениях переменных.)
Так как двоеточие может легально присутствовать в SQL-командах, попытка подстановки (например для :name
, :'name'
или :"name"
) не выполняется, если переменная не установлена. В любом случае можно экранировать двоеточие с помощью обратной косой черты, чтобы предотвратить подстановку.
Использование двоеточия для переменных является стандартом SQL для встраиваемых языков запросов, таких как ECPG. Использование двоеточия для срезов массивов и приведения типов является расширениями Postgres Pro, что иногда может конфликтовать со стандартным использованием. Использование двоеточия и кавычек для экранирования значения переменной при подстановке в качестве SQL литерала или идентификатора — это расширение psql.
Настройка приглашений
Приглашения, выдаваемые psql, можно настроить по своему вкусу. Три переменные PROMPT1
, PROMPT2
и PROMPT3
содержат строки и спецпоследовательности, задающие внешний вид приглашения. Приглашение 1 (PROMPT1
) — это обычное приглашение, которое выдаётся, когда psql ожидает ввода новой команды. Приглашение 2 (PROMPT2
) выдаётся, когда при вводе команды ожидается дополнительные строки, например потому что команда не была завершена точкой с запятой или не закрыты кавычки. Приглашение 3 (PROMPT3
) выдаётся при выполнении SQL-команды COPY FROM STDIN
, когда в терминале нужно ввести значение новой строки.
Значения этих переменных выводятся буквально, за исключением случаев, когда в них встречается знак процента (%
). В зависимости от следующего символа будет подставляться определённый текст. Существуют следующие подстановки:
%M
Полное имя компьютера (с именем домена) сервера базы данных или
[local]
, если подключение выполнено через Unix-сокет, либо[local:
, если при компиляции был изменён путь Unix-сокета по умолчанию./каталог/имя
]%m
Имя компьютера, где работает сервер баз данных, усечённое до первой точки или
[local]
, если подключение выполнено через Unix-сокет.%>
Номер порта, который прослушивает сервер базы данных.
%n
Имя пользователя базы данных для текущей сессии. (Это значение может меняться в течение сессии в результате выполнения команды
SET SESSION AUTHORIZATION
.)%/
Имя текущей базы данных.
%~
Похоже на
%/
, но выводит тильду~
, если текущая база данных совпадает с базой данных по умолчанию.%#
Если пользователь текущей сессии является суперпользователем базы данных, то выводит
#
, иначе>
. (Это значение может меняться в течение сессии в результате выполнения командыSET SESSION AUTHORIZATION
.)%p
PID обслуживающего процесса для текущего подключения.
%R
В приглашении 1 это обычно символ
=
, но^
в однострочном режиме, либо!
, если сеанс не подключён к базе данных (что возможно при ошибке\connect
). В приглашении 2%R
заменяется символом, показывающим, почему psql ожидает дополнительный ввод:-
, если команда просто ещё не была завершена, но*
, если не завершён комментарий/* ... */
; апостроф, если не завершена строка в апострофах; кавычки, если не завершён идентификатор в кавычках; знак доллара, если не завершена строка в долларах; либо(
, если после открывающей скобки не хватает закрывающей. В приглашении 3%R
не выдаёт ничего.%x
Состояние транзакции: пустая строка, если не в транзакционном блоке;
*
, когда в транзакционном блоке;!
, когда в транзакционном блоке, в котором произошла ошибка и?
, когда состояние транзакции не определено (например, нет подключения к базе данных).%l
Номер строки в текущем операторе, начиная с
1
.%
цифры
Подставляется символ с указанным восьмеричным кодом.
%:
имя
:
Значение переменной psql
имя
. За подробностями обратитесь к разделу Переменные.%`
команда
`
Подставляется вывод
команды
, как и в обычной подстановке с обратными апострофами.%[
...%]
Приглашения могут содержать управляющие символы терминала, которые, например, изменяют цвет, фон и стиль текста приглашения или изменяют заголовок окна терминала. Для того, чтобы возможности редактирования Readline работали правильно, непечатаемые символы нужно расположить между
%[
и%]
, чтобы сделать невидимыми. Можно делать несколько таких включений в приглашение. Например:testdb=> \set PROMPT1 '%[%033[1;33;40m%]%n@%/%R%[%033[0m%]%# '
выдаст жирное (
1;
), желтое на черном (33;40
) приглашение для VT100 совместимых цветных терминалов.
Чтобы вставить знак процента, нужно написать %%
. По умолчанию используются значения '%/%R%# '
для PROMPT1
и PROMPT2
и '>> '
для PROMPT3
.
Примечание
Эта функциональность была бессовестно списана с tcsh.
Редактирование командной строки
psql поддерживает библиотеку Readline для удобного редактирования командной строки. История команд автоматически сохраняется при выходе из psql и загружается при запуске. Завершение клавишей TAB
также поддерживается, хотя логика завершения не претендует на роль анализатора SQL. Запросы, генерируемые завершением по TAB
, также могут конфликтовать с другими командами SQL, например SET TRANSACTION ISOLATION LEVEL
. Если по какой-либо причине вам не нравится завершение по клавише TAB
, его можно отключить в файле .inputrc
в вашем домашнем каталоге:
$if psql set disable-completion on $endif
(Это возможность не psql, а Readline. Читайте документацию к Readline для дополнительной информации.)
Переменные окружения
COLUMNS
Если
\pset columns
равно нулю, управляет шириной формата выводаwrapped
, а также определяет, нужно ли использовать постраничник и нужно ли переключаться в вертикальный формат в режимеexpanded auto
.PAGER
Если результат запроса не помещается на экране, он пропускается через эту программу. Обычно это
more
илиless
. Значение по умолчанию зависит от платформы. От использования постраничника можно отказаться, очистив переменнуюPAGER
или установив соответствующие параметры с помощью команды\pset
.PGDATABASE
PGHOST
PGPORT
PGUSER
Параметры подключения по умолчанию (см. Раздел 32.14).
PSQL_EDITOR
EDITOR
VISUAL
Редактор, используемый командами
\e
,\ef
и\ev
. Эти переменные рассматриваются в этом же порядке; в силу вступает значение, установленное первым.По умолчанию в Unix-подобных системах используется
vi
, а в Windows —notepad.exe
.PSQL_EDITOR_LINENUMBER_ARG
Если в командах
\e
,\ef
или\ev
указан номер строки, эта переменная задаёт аргумент командной строки, с которым номер строки может быть передан в редактор. Например, для редакторов Emacs и vi это знак плюс. Добавьте в конец значения пробел, если он требуется для отделения имени аргумента от номера строки. Примеры:PSQL_EDITOR_LINENUMBER_ARG='+' PSQL_EDITOR_LINENUMBER_ARG='--line '
Значение по умолчанию
+
в Unix-подобных системах (соответствует редактору по умолчаниюvi
и многим другим распространённым редакторам). На платформе Windows нет значения по умолчанию.PSQL_HISTORY
Альтернативное расположение файла с историей команд. Допускается использование тильды (
~
).PSQLRC
Альтернативное расположение пользовательского файла
.psqlrc
. Допускается использование тильды (~
).SHELL
Команда операционной системы, выполняемая метакомандой
\!
.TMPDIR
Каталог для хранения временных файлов. По умолчанию
/tmp
.
Эта утилита, как и большинство других утилит Postgres Pro, также использует переменные среды, поддерживаемые libpq (см. Раздел 32.14).
Файлы
psqlrc
и~/.psqlrc
При запуске без параметра
-X
программа psql пытается считать и выполнить команды из общесистемного стартового файла (psqlrc
), а затем из персонального стартового файла пользователя (~/.psqlrc
), после подключения к базе данных, но перед получением обычных команд. Этими файлами можно воспользоваться для настройки клиента и/или сервера, как правило, с помощью команд\set
иSET
.Общесистемный стартовый файл называется
psqlrc
, он будет искаться в каталоге установки «конфигурация системы». Для того чтобы узнать этот каталог, надёжнее всего выполнить командуpg_config --sysconfdir
. По умолчанию он расположен в../etc/
относительно каталога, содержащего исполняемые файлы Postgres Pro. Имя этого каталога можно задать явно через переменную окруженияPGSYSCONFDIR
.Персональный стартовый файл пользователя называется
.psqlrc
, он будет искаться в домашнем каталоге вызывающего пользователя. В Windows, где отсутствует такое понятие, персональный стартовый файл называется%APPDATA%\postgresql\psqlrc.conf
. Расположение персонального стартового файла пользователя можно задать явно через переменную окруженияPSQLRC
.Оба стартовых файла, общесистемный и персональный, можно привязать к конкретной версии psql. Для этого в конце имени файла нужно добавить номер основного или корректирующего релиза Postgres Pro, например
~/.psqlrc-9.2
или~/.psqlrc-9.2.5
. При наличии нескольких файлов, файл с более детальным номером версии будет иметь предпочтение..psql_history
История командной строки хранится в файле
~/.psql_history
или%APPDATA%\postgresql\psql_history
на Windows.Расположение файла истории можно задать явно через переменную окружения
PSQL_HISTORY
.
Замечания
psql лучше всего работает с серверами той же или более старой основной версии. Сбой метакоманды наиболее вероятен, если версия сервера новее, чем версия psql. Однако команды семейства
\d
должны работать с версиями сервера до 7.4, хотя и необязательно с серверами новее, чем сам psql. Общая функциональность запуска SQL-команд и отображения результатов запросов также должна работать на серверах с более новой основной версией, но это не гарантируется во всех случаях.Если вы хотите, применяя psql, подключаться к нескольким серверам с различными основными версиями, рекомендуется использовать последнюю версию psql. Также можно собрать копии psql от каждой основной версии и использовать ту, которая соответствует версии сервера. Но на практике в этих дополнительных сложностях нет необходимости.
В Postgres Pro до версии 9.6 параметр
-c
подразумевал-X
(--no-psqlrc
); теперь это не так.В PostgreSQL до 8.4 программа psql могла принять первый аргумент однобуквенной команды с обратной косой чертой сразу после команды, без промежуточного пробела. Теперь разделительный пробельный символ обязателен.
Замечания для пользователей Windows
psql создан как «консольное приложение». Поскольку в Windows консольные окна используют кодировку символов отличную от той, что используется для остальной системы, нужно проявить особую осторожность при использовании 8-битных символов. Если psql обнаружит проблемную кодовую страницу консоли, он предупредит вас при запуске. Чтобы изменить кодовую страницу консоли, необходимы две вещи:
Задать кодовую страницу, выполнив
cmd.exe /c chcp 1251
. (1251 это кодовая страница для России, замените на ваше значение.) При использовании Cygwin, эту команду можно записать в/etc/profile
.Установите консольный шрифт в
Lucida Console
, потому что растровый шрифт не работает с кодовой страницей ANSI.
Примеры
Первый пример показывает, что для ввода одной команды может потребоваться несколько строк. Обратите внимание, как меняется приглашение:
testdb=>CREATE TABLE my_table (
testdb(>first integer not null default 0,
testdb(>second text)
testdb->;
CREATE TABLE
Теперь посмотрим на определение таблицы:
testdb=> \d my_table
Таблица "my_table"
Атрибут | Тип | Модификаторы
---------+---------+--------------------
first | integer | NOT NULL DEFAULT 0
second | text |
Теперь изменим приглашение на что-то более интересное:
testdb=> \set PROMPT1 '%n@%m %~%R%# '
peter@localhost testdb=>
Предположим, что вы внесли данные в таблицу и хотите на них посмотреть:
peter@localhost testdb=> SELECT * FROM my_table; first | second -------+-------- 1 | Один 2 | Два 3 | Три 4 | Четыре (4 строки)
Таблицу можно вывести разными способами при помощи команды \pset
:
peter@localhost testdb=>\pset border 2
Установлен стиль границ: 2. peter@localhost testdb=>SELECT * FROM my_table;
+-------+--------+ | first | second | +-------+--------+ | 1 | Один | | 2 | Два | | 3 | Три | | 4 | Четыре | +-------+--------+ (4 строки) peter@localhost testdb=>\pset border 0
Установлен стиль границ: 0. peter@localhost testdb=>SELECT * FROM my_table;
first second ----- ------ 1 Один 2 Два 3 Три 4 Четыре (4 строки) peter@localhost testdb=>\pset border 1
Установлен стиль границ: 1. peter@localhost testdb=>\pset format unaligned
Формат вывода: unaligned. peter@localhost testdb=>\pset fieldsep ','
Разделитель полей: ",". peter@localhost testdb=>\pset tuples_only
Выводятся только кортежи. peter@localhost testdb=>SELECT second, first FROM my_table;
Один,1 Два,2 Три,3 Четыре,4
Также можно использовать короткие команды:
peter@localhost testdb=>\a \t \x
Формат вывода: aligned. Режим вывода только кортежей выключен. Расширенный вывод включён. peter@localhost testdb=>SELECT * FROM my_table;
-[ RECORD 1 ]- first | 1 second | Один -[ RECORD 2 ]- first | 2 second | Два -[ RECORD 3 ]- first | 3 second | Три -[ RECORD 4 ]- first | 4 second | Четыре
Когда это уместно, результаты запроса можно просмотреть в виде перекрёстной таблицы с помощью команды \crosstabview
:
testdb=>SELECT first, second, first > 2 AS gt2 FROM my_table;
first | second | gt2 -------+--------+----- 1 | one | f 2 | two | f 3 | three | t 4 | four | t (4 rows) testdb=>\crosstabview first second
first | one | two | three | four -------+-----+-----+-------+------ 1 | f | | | 2 | | f | | 3 | | | t | 4 | | | | t (4 rows)
Второй пример показывает таблицу умножения, строки в которой отсортированы в обратном числовом порядке, а столбцы — независимо, по возрастанию числовых значений.
testdb=>SELECT t1.first as "A", t2.first+100 AS "B", t1.first*(t2.first+100) as "AxB",
testdb(>row_number() over(order by t2.first) AS ord
testdb(>FROM my_table t1 CROSS JOIN my_table t2 ORDER BY 1 DESC
testdb(>\crosstabview "A" "B" "AxB" ord
A | 101 | 102 | 103 | 104 ---+-----+-----+-----+----- 4 | 404 | 408 | 412 | 416 3 | 303 | 306 | 309 | 312 2 | 202 | 204 | 206 | 208 1 | 101 | 102 | 103 | 104 (4 rows)