Connecting to a Database
psql is a regular PostgreSQL client application. In order to connect to a database you need to know the name of your target database, the host name and port number of the server, and what database user name you want to connect as. psql can be told about those parameters via command line options, namely -d
, -h
, -p
, and -U
respectively. If an argument is found that does not belong to any option it will be interpreted as the database name (or the database user name, if the database name is already given). Not all of these options are required; there are useful defaults. If you omit the host name, psql will connect via a Unix-domain socket to a server on the local host, or via TCP/IP to localhost
on Windows. The default port number is determined at compile time. Since the database server uses the same default, you will not have to specify the port in most cases. The default database user name is your operating-system user name. Once the database user name is determined, it is used as the default database name. Note that you cannot just connect to any database under any database user name. Your database administrator should have informed you about your access rights.
When the defaults aren’t quite right, you can save yourself some typing by setting the environment variables PGDATABASE
, PGHOST
, PGPORT
and/or PGUSER
to appropriate values. (For additional environment variables, see Section 32.15.) It is also convenient to have a ~/.pgpass
file to avoid regularly having to type in passwords. See Section 32.16 for more information.
An alternative way to specify connection parameters is in a conninfo
string or a URI, which is used instead of a database name. This mechanism give you very wide control over the connection. For example:
$psql "service=myservice sslmode=require"
$psql postgresql://dbmaster:5433/mydb?sslmode=require
This way you can also use LDAP for connection parameter lookup as described in Section 32.18. See Section 32.1.2 for more information on all the available connection options.
If the connection could not be made for any reason (e.g., insufficient privileges, server is not running on the targeted host, etc.), psql will return an error and terminate.
If both standard input and standard output are a terminal, then psql sets the client encoding to “auto”, which will detect the appropriate client encoding from the locale settings (LC_CTYPE
environment variable on Unix systems). If this doesn’t work out as expected, the client encoding can be overridden using the environment variable PGCLIENTENCODING
.
Entering SQL Commands
In normal operation, psql provides a prompt with the name of the database to which psql is currently connected, followed by the string =>
. For example:
$ psql testdb
psql (17.4)
Type "help" for help.
testdb=>
At the prompt, the user can type in SQL commands. Ordinarily, input lines are sent to the server when a command-terminating semicolon is reached. An end of line does not terminate a command. Thus commands can be spread over several lines for clarity. If the command was sent and executed without error, the results of the command are displayed on the screen.
If untrusted users have access to a database that has not adopted a secure schema usage pattern, begin your session by removing publicly-writable schemas from search_path
. One can add options=-csearch_path=
to the connection string or issue SELECT pg_catalog.set_config('search_path', '', false)
before other SQL commands. This consideration is not specific to psql; it applies to every interface for executing arbitrary SQL commands.
Whenever a command is executed, psql also polls for asynchronous notification events generated by LISTEN
and NOTIFY
.
While C-style block comments are passed to the server for processing and removal, SQL-standard comments are removed by psql.
Advanced Features
Variables
psql provides variable substitution features similar to common Unix command shells. Variables are simply name/value pairs, where the value can be any string of any length. The name must consist of letters (including non-Latin letters), digits, and underscores.
To set a variable, use the psql meta-command \set
. For example,
testdb=> \set foo bar
sets the variable foo
to the value bar
. To retrieve the content of the variable, precede the name with a colon, for example:
testdb=> \echo :foo
bar
This works in both regular SQL commands and meta-commands; there is more detail in SQL Interpolation, below.
If you call \set
without a second argument, the variable is set to an empty-string value. To unset (i.e., delete) a variable, use the command \unset
. To show the values of all variables, call \set
without any argument.
Note
The arguments of \set
are subject to the same substitution rules as with other commands. Thus you can construct interesting references such as \set :foo 'something'
and get “soft links” or “variable variables” of Perl or PHP fame, respectively. Unfortunately (or fortunately?), there is no way to do anything useful with these constructs. On the other hand, \set bar :foo
is a perfectly valid way to copy a variable.
A number of these variables are treated specially by psql. They represent certain option settings that can be changed at run time by altering the value of the variable, or in some cases represent changeable state of psql. By convention, all specially treated variables’ names consist of all upper-case ASCII letters (and possibly digits and underscores). To ensure maximum compatibility in the future, avoid using such variable names for your own purposes.
Variables that control psql‘s behavior generally cannot be unset or set to invalid values. An \unset
command is allowed but is interpreted as setting the variable to its default value. A \set
command without a second argument is interpreted as setting the variable to on
, for control variables that accept that value, and is rejected for others. Also, control variables that accept the values on
and off
will also accept other common spellings of Boolean values, such as true
and false
.
The specially treated variables are:
AUTOCOMMIT
#-
When
on
(the default), each SQL command is automatically committed upon successful completion. To postpone commit in this mode, you must enter aBEGIN
orSTART TRANSACTION
SQL command. Whenoff
or unset, SQL commands are not committed until you explicitly issueCOMMIT
orEND
. The autocommit-off mode works by issuing an implicitBEGIN
for you, just before any command that is not already in a transaction block and is not itself aBEGIN
or other transaction-control command, nor a command that cannot be executed inside a transaction block (such asVACUUM
).Note
In autocommit-off mode, you must explicitly abandon any failed transaction by entering
ABORT
orROLLBACK
. Also keep in mind that if you exit the session without committing, your work will be lost.Note
The autocommit-on mode is PostgreSQL‘s traditional behavior, but autocommit-off is closer to the SQL spec. If you prefer autocommit-off, you might wish to set it in the system-wide
psqlrc
file or your~/.psqlrc
file. COMP_KEYWORD_CASE
#-
Determines which letter case to use when completing an SQL key word. If set to
lower
orupper
, the completed word will be in lower or upper case, respectively. If set topreserve-lower
orpreserve-upper
(the default), the completed word will be in the case of the word already entered, but words being completed without anything entered will be in lower or upper case, respectively. DBNAME
#-
The name of the database you are currently connected to. This is set every time you connect to a database (including program start-up), but can be changed or unset.
ECHO
#-
If set to
all
, all nonempty input lines are printed to standard output as they are read. (This does not apply to lines read interactively.) To select this behavior on program start-up, use the switch-a
. If set toqueries
, psql prints each query to standard output as it is sent to the server. The switch to select this behavior is-e
. If set toerrors
, then only failed queries are displayed on standard error output. The switch for this behavior is-b
. If set tonone
(the default), then no queries are displayed. ECHO_HIDDEN
#-
When this variable is set to
on
and a backslash command queries the database, the query is first shown. This feature helps you to study PostgreSQL internals and provide similar functionality in your own programs. (To select this behavior on program start-up, use the switch-E
.) If you set this variable to the valuenoexec
, the queries are just shown but are not actually sent to the server and executed. The default value isoff
. ENCODING
#-
The current client character set encoding. This is set every time you connect to a database (including program start-up), and when you change the encoding with
\encoding
, but it can be changed or unset. ERROR
#-
true
if the last SQL query failed,false
if it succeeded. See alsoSQLSTATE
. FETCH_COUNT
#-
If this variable is set to an integer value greater than zero, the results of
SELECT
queries are fetched and displayed in groups of that many rows, rather than the default behavior of collecting the entire result set before display. Therefore only a limited amount of memory is used, regardless of the size of the result set. Settings of 100 to 1000 are commonly used when enabling this feature. Keep in mind that when using this feature, a query might fail after having already displayed some rows.Tip
Although you can use any output format with this feature, the default
aligned
format tends to look bad because each group ofFETCH_COUNT
rows will be formatted separately, leading to varying column widths across the row groups. The other output formats work better. HIDE_TABLEAM
#-
If this variable is set to
true
, a table’s access method details are not displayed. This is mainly useful for regression tests. HIDE_TOAST_COMPRESSION
#-
If this variable is set to
true
, column compression method details are not displayed. This is mainly useful for regression tests. HISTCONTROL
#-
If this variable is set to
ignorespace
, lines which begin with a space are not entered into the history list. If set to a value ofignoredups
, lines matching the previous history line are not entered. A value ofignoreboth
combines the two options. If set tonone
(the default), all lines read in interactive mode are saved on the history list.Note
This feature was shamelessly plagiarized from Bash.
HISTFILE
#-
The file name that will be used to store the history list. If unset, the file name is taken from the
PSQL_HISTORY
environment variable. If that is not set either, the default is~/.psql_history
, or%APPDATA%\postgresql\psql_history
on Windows. For example, putting:\set HISTFILE ~/.psql_history-:DBNAME
in
~/.psqlrc
will cause psql to maintain a separate history for each database.Note
This feature was shamelessly plagiarized from Bash.
HISTSIZE
#-
The maximum number of commands to store in the command history (default 500). If set to a negative value, no limit is applied.
Note
This feature was shamelessly plagiarized from Bash.
HOST
#-
The database server host you are currently connected to. This is set every time you connect to a database (including program start-up), but can be changed or unset.
IGNOREEOF
#-
If set to 1 or less, sending an EOF character (usually Control+D) to an interactive session of psql will terminate the application. If set to a larger numeric value, that many consecutive EOF characters must be typed to make an interactive session terminate. If the variable is set to a non-numeric value, it is interpreted as 10. The default is 0.
Note
This feature was shamelessly plagiarized from Bash.
LASTOID
#-
The value of the last affected OID, as returned from an
INSERT
or\lo_import
command. This variable is only guaranteed to be valid until after the result of the next SQL command has been displayed. PostgreSQL servers since version 12 do not support OID system columns anymore, thus LASTOID will always be 0 followingINSERT
when targeting such servers. LAST_ERROR_MESSAGE
LAST_ERROR_SQLSTATE
#-
The primary error message and associated SQLSTATE code for the most recent failed query in the current psql session, or an empty string and
00000
if no error has occurred in the current session. ON_ERROR_ROLLBACK
#-
When set to
on
, if a statement in a transaction block generates an error, the error is ignored and the transaction continues. When set tointeractive
, such errors are only ignored in interactive sessions, and not when reading script files. When set tooff
(the default), a statement in a transaction block that generates an error aborts the entire transaction. The error rollback mode works by issuing an implicitSAVEPOINT
for you, just before each command that is in a transaction block, and then rolling back to the savepoint if the command fails. ON_ERROR_STOP
#-
By default, command processing continues after an error. When this variable is set to
on
, processing will instead stop immediately. In interactive mode, psql will return to the command prompt; otherwise, psql will exit, returning error code 3 to distinguish this case from fatal error conditions, which are reported using error code 1. In either case, any currently running scripts (the top-level script, if any, and any other scripts which it may have in invoked) will be terminated immediately. If the top-level command string contained multiple SQL commands, processing will stop with the current command. PORT
#-
The database server port to which you are currently connected. This is set every time you connect to a database (including program start-up), but can be changed or unset.
PROMPT1
PROMPT2
PROMPT3
#-
These specify what the prompts psql issues should look like. See Prompting below.
QUIET
#-
Setting this variable to
on
is equivalent to the command line option-q
. It is probably not too useful in interactive mode. ROW_COUNT
#-
The number of rows returned or affected by the last SQL query, or 0 if the query failed or did not report a row count.
SERVER_VERSION_NAME
SERVER_VERSION_NUM
#-
The server’s version number as a string, for example
9.6.2
,10.1
or11beta1
, and in numeric form, for example90602
or100001
. These are set every time you connect to a database (including program start-up), but can be changed or unset. SHELL_ERROR
#-
true
if the last shell command failed,false
if it succeeded. This applies to shell commands invoked via the\!
,\g
,\o
,\w
, and\copy
meta-commands, as well as backquote (`
) expansion. Note that for\o
, this variable is updated when the output pipe is closed by the next\o
command. See alsoSHELL_EXIT_CODE
. SHELL_EXIT_CODE
#-
The exit status returned by the last shell command. 0–127 represent program exit codes, 128–255 indicate termination by a signal, and -1 indicates failure to launch a program or to collect its exit status. This applies to shell commands invoked via the
\!
,\g
,\o
,\w
, and\copy
meta-commands, as well as backquote (`
) expansion. Note that for\o
, this variable is updated when the output pipe is closed by the next\o
command. See alsoSHELL_ERROR
. SHOW_ALL_RESULTS
#-
When this variable is set to
off
, only the last result of a combined query (\;
) is shown instead of all of them. The default ison
. The off behavior is for compatibility with older versions of psql. SHOW_CONTEXT
#-
This variable can be set to the values
never
,errors
, oralways
to control whetherCONTEXT
fields are displayed in messages from the server. The default iserrors
(meaning that context will be shown in error messages, but not in notice or warning messages). This setting has no effect whenVERBOSITY
is set toterse
orsqlstate
. (See also\errverbose
, for use when you want a verbose version of the error you just got.) SINGLELINE
#-
Setting this variable to
on
is equivalent to the command line option-S
. SINGLESTEP
#-
Setting this variable to
on
is equivalent to the command line option-s
. SQLSTATE
#-
The error code (see Appendix A) associated with the last SQL query’s failure, or
00000
if it succeeded. USER
#-
The database user you are currently connected as. This is set every time you connect to a database (including program start-up), but can be changed or unset.
VERBOSITY
#-
This variable can be set to the values
default
,verbose
,terse
, orsqlstate
to control the verbosity of error reports. (See also\errverbose
, for use when you want a verbose version of the error you just got.) VERSION
VERSION_NAME
VERSION_NUM
#-
These variables are set at program start-up to reflect psql‘s version, respectively as a verbose string, a short string (e.g.,
9.6.2
,10.1
, or11beta1
), and a number (e.g.,90602
or100001
). They can be changed or unset.
SQL Interpolation
A key feature of psql variables is that you can substitute (“interpolate”) them into regular SQL statements, as well as the arguments of meta-commands. Furthermore, psql provides facilities for ensuring that variable values used as SQL literals and identifiers are properly quoted. The syntax for interpolating a value without any quoting is to prepend the variable name with a colon (:
). For example,
testdb=>\set foo 'my_table'
testdb=>SELECT * FROM :foo;
would query the table my_table
. Note that this may be unsafe: the value of the variable is copied literally, so it can contain unbalanced quotes, or even backslash commands. You must make sure that it makes sense where you put it.
When a value is to be used as an SQL literal or identifier, it is safest to arrange for it to be quoted. To quote the value of a variable as an SQL literal, write a colon followed by the variable name in single quotes. To quote the value as an SQL identifier, write a colon followed by the variable name in double quotes. These constructs deal correctly with quotes and other special characters embedded within the variable value. The previous example would be more safely written this way:
testdb=>\set foo 'my_table'
testdb=>SELECT * FROM :"foo";
Variable interpolation will not be performed within quoted SQL literals and identifiers. Therefore, a construction such as ':foo'
doesn’t work to produce a quoted literal from a variable’s value (and it would be unsafe if it did work, since it wouldn’t correctly handle quotes embedded in the value).
One example use of this mechanism is to copy the contents of a file into a table column. First load the file into a variable and then interpolate the variable’s value as a quoted string:
testdb=>\set content `cat my_file.txt`
testdb=>INSERT INTO my_table VALUES (:'content');
(Note that this still won’t work if my_file.txt
contains NUL bytes. psql does not support embedded NUL bytes in variable values.)
Since colons can legally appear in SQL commands, an apparent attempt at interpolation (that is, :name
, :'name'
, or :"name"
) is not replaced unless the named variable is currently set. In any case, you can escape a colon with a backslash to protect it from substitution.
The :{?
special syntax returns TRUE or FALSE depending on whether the variable exists or not, and is thus always substituted, unless the colon is backslash-escaped.name
}
The colon syntax for variables is standard SQL for embedded query languages, such as ECPG. The colon syntaxes for array slices and type casts are PostgreSQL extensions, which can sometimes conflict with the standard usage. The colon-quote syntax for escaping a variable’s value as an SQL literal or identifier is a psql extension.
Prompting
The prompts psql issues can be customized to your preference. The three variables PROMPT1
, PROMPT2
, and PROMPT3
contain strings and special escape sequences that describe the appearance of the prompt. Prompt 1 is the normal prompt that is issued when psql requests a new command. Prompt 2 is issued when more input is expected during command entry, for example because the command was not terminated with a semicolon or a quote was not closed. Prompt 3 is issued when you are running an SQL COPY FROM STDIN
command and you need to type in a row value on the terminal.
The value of the selected prompt variable is printed literally, except where a percent sign (%
) is encountered. Depending on the next character, certain other text is substituted instead. Defined substitutions are:
%M
#-
The full host name (with domain name) of the database server, or
[local]
if the connection is over a Unix domain socket, or[local:
, if the Unix domain socket is not at the compiled in default location./dir/name
] %m
#-
The host name of the database server, truncated at the first dot, or
[local]
if the connection is over a Unix domain socket. %>
#-
The port number at which the database server is listening.
%n
#-
The database session user name. (The expansion of this value might change during a database session as the result of the command
SET SESSION AUTHORIZATION
.) %/
#-
The name of the current database.
%~
#-
Like
%/
, but the output is~
(tilde) if the database is your default database. %#
#-
If the session user is a database superuser, then a
#
, otherwise a>
. (The expansion of this value might change during a database session as the result of the commandSET SESSION AUTHORIZATION
.) %p
#-
The process ID of the backend currently connected to.
%R
#-
In prompt 1 normally
=
, but@
if the session is in an inactive branch of a conditional block, or^
if in single-line mode, or!
if the session is disconnected from the database (which can happen if\connect
fails). In prompt 2%R
is replaced by a character that depends on why psql expects more input:-
if the command simply wasn’t terminated yet, but*
if there is an unfinished/* ... */
comment, a single quote if there is an unfinished quoted string, a double quote if there is an unfinished quoted identifier, a dollar sign if there is an unfinished dollar-quoted string, or(
if there is an unmatched left parenthesis. In prompt 3%R
doesn’t produce anything. %x
#-
Transaction status: an empty string when not in a transaction block, or
*
when in a transaction block, or!
when in a failed transaction block, or?
when the transaction state is indeterminate (for example, because there is no connection). %l
#-
The line number inside the current statement, starting from
1
. %
digits
#-
The character with the indicated octal code is substituted.
%:
name
:
#-
The value of the psql variable
name
. See Variables, above, for details. %`
command
`
#-
The output of
command
, similar to ordinary “back-tick” substitution. %[
…%]
#-
Prompts can contain terminal control characters which, for example, change the color, background, or style of the prompt text, or change the title of the terminal window. In order for the line editing features of Readline to work properly, these non-printing control characters must be designated as invisible by surrounding them with
%[
and%]
. Multiple pairs of these can occur within the prompt. For example:testdb=> \set PROMPT1 '%[%033[1;33;40m%]%n@%/%R%[%033[0m%]%# '
results in a boldfaced (
1;
) yellow-on-black (33;40
) prompt on VT100-compatible, color-capable terminals. %w
#-
Whitespace of the same width as the most recent output of
PROMPT1
. This can be used as aPROMPT2
setting, so that multi-line statements are aligned with the first line, but there is no visible secondary prompt.
To insert a percent sign into your prompt, write %%
. The default prompts are '%/%R%x%# '
for prompts 1 and 2, and '>> '
for prompt 3.
Note
This feature was shamelessly plagiarized from tcsh.
Command-Line Editing
psql uses the Readline or libedit library, if available, for convenient line editing and retrieval. The command history is automatically saved when psql exits and is reloaded when psql starts up. Type up-arrow or control-P to retrieve previous lines.
You can also use tab completion to fill in partially-typed keywords and SQL object names in many (by no means all) contexts. For example, at the start of a command, typing ins
and pressing TAB will fill in insert into
. Then, typing a few characters of a table or schema name and pressing TAB
will fill in the unfinished name, or offer a menu of possible completions when there’s more than one. (Depending on the library in use, you may need to press TAB
more than once to get a menu.)
Tab completion for SQL object names requires sending queries to the server to find possible matches. In some contexts this can interfere with other operations. For example, after BEGIN
it will be too late to issue SET TRANSACTION ISOLATION LEVEL
if a tab-completion query is issued in between. If you do not want tab completion at all, you can turn it off permanently by putting this in a file named .inputrc
in your home directory:
$if psql set disable-completion on $endif
(This is not a psql but a Readline feature. Read its documentation for further details.)
The -n
(--no-readline
) command line option can also be useful to disable use of Readline for a single run of psql. This prevents tab completion, use or recording of command line history, and editing of multi-line commands. It is particularly useful when you need to copy-and-paste text that contains TAB
characters.
������������� ������� ��������� ��������� ���������� (man-��)
psql (1)
NAME
psql - PostgreSQL interactive terminal
SYNOPSIS
psql [ option… ] [ dbname
[ username ] ]
DESCRIPTION
psql is a terminal-based front-end to
PostgreSQL. It enables you to type in
queries interactively, issue them to
PostgreSQL, and see the query results.
Alternatively, input can be from a file. In addition, it provides a
number of meta-commands and various shell-like features to
facilitate writing scripts and automating a wide variety of tasks.
OPTIONS
- -a
- —echo-all
-
Print all input lines to standard output as they are read. This is more
useful for script processing rather than interactive mode. This is
equivalent to setting the variable ECHO to
all. - -A
- —no-align
-
Switches to unaligned output mode. (The default output mode is
otherwise aligned.) - -c command
- —command command
-
Specifies that psql is to execute one
command string, command,
and then exit. This is useful in shell scripts.command must be either
a command string that is completely parsable by the server (i.e.,
it contains no psql specific features),
or a single backslash command. Thus you cannot mix
SQL and psql
meta-commands. To achieve that, you could pipe the string into
psql, like this: echo «\x \\
select * from foo;» | psql.If the command string contains multiple SQL commands, they are
processed in a single transaction, unless there are explicit
BEGIN/COMMIT commands included in the string to divide it into
multiple transactions. This is different from the behavior when
the same string is fed to psql‘s standard input. - -d dbname
- —dbname dbname
-
Specifies the name of the database to connect to. This is
equivalent to specifying dbname as the first non-option
argument on the command line. - -e
- —echo-queries
-
Copy all SQL commands sent to the server to standard output as well.
This is equivalent
to setting the variable ECHO to
queries. - -E
- —echo-hidden
-
Echo the actual queries generated by \d and other backslash
commands. You can use this to study psql‘s
internal operations. This is equivalent to
setting the variable ECHO_HIDDEN from within
psql. - -f filename
- —file filename
-
Use the file filename
as the source of commands instead of reading commands interactively.
After the file is processed, psql
terminates. This is in many ways equivalent to the internal
command \i.If filename is —
(hyphen), then standard input is read.Using this option is subtly different from writing psql
< filename. In general,
both will do what you expect, but using -f
enables some nice features such as error messages with line
numbers. There is also a slight chance that using this option will
reduce the start-up overhead. On the other hand, the variant using
the shell’s input redirection is (in theory) guaranteed to yield
exactly the same output that you would have gotten had you entered
everything by hand. - -F separator
- —field-separator separator
-
Use separator as the
field separator for unaligned output. This is equivalent to
\pset fieldsep or \f. - -h hostname
- —host hostname
-
Specifies the host name of the machine on which the
server is running. If the value begins
with a slash, it is used as the directory for the Unix-domain
socket. - -H
- —html
-
Turn on HTML tabular output. This is
equivalent to \pset format html or the
\H command. - -l
- —list
-
List all available databases, then exit. Other non-connection
options are ignored. This is similar to the internal command
\list. - -L filename
- —log-file filename
-
Write all query output into file filename, in addition to the
normal output destination. - -o filename
- —output filename
-
Put all query output into file filename. This is equivalent to
the command \o. - -p port
- —port port
-
Specifies the TCP port or the local Unix-domain
socket file extension on which the server is listening for
connections. Defaults to the value of the PGPORT
environment variable or, if not set, to the port specified at
compile time, usually 5432. - -P assignment
- —pset assignment
-
Allows you to specify printing options in the style of
\pset on the command line. Note that here you
have to separate name and value with an equal sign instead of a
space. Thus to set the output format to LaTeX, you could write
-P format=latex. - -q
- —quiet
-
Specifies that psql should do its work
quietly. By default, it prints welcome messages and various
informational output. If this option is used, none of this
happens. This is useful with the -c option.
Within psql you can also set the
QUIET variable to achieve the same effect. - -R separator
- —record-separator separator
-
Use separator as the
record separator for unaligned output. This is equivalent to the
\pset recordsep command. - -s
- —single-step
-
Run in single-step mode. That means the user is prompted before
each command is sent to the server, with the option to cancel
execution as well. Use this to debug scripts. - -S
- —single-line
-
Runs in single-line mode where a newline terminates an SQL command, as a
semicolon does.-
Note:
This mode is provided for those who insist on it, but you are not
necessarily encouraged to use it. In particular, if you mix
SQL and meta-commands on a line the order of
execution might not always be clear to the inexperienced user.
-
Note:
- -t
- —tuples-only
-
Turn off printing of column names and result row count footers,
etc. This is equivalent to the \t command. - -T table_options
- —table-attr table_options
-
Allows you to specify options to be placed within the
HTML table tag. See
\pset for details. - -u
-
Forces psql to prompt for the user name and
password before connecting to the database.This option is deprecated, as it is conceptually flawed.
(Prompting for a non-default user name and prompting for a
password because the server requires it are really two different
things.) You are encouraged to look at the -U and
-W options instead. - -U username
- —username username
-
Connect to the database as the user username instead of the default.
(You must have permission to do so, of course.) - -v assignment
- —set assignment
- —variable assignment
-
Perform a variable assignment, like the \set
internal command. Note that you must separate name and value, if
any, by an equal sign on the command line. To unset a variable,
leave off the equal sign. To just set a variable without a value,
use the equal sign but leave off the value. These assignments are
done during a very early stage of start-up, so variables reserved
for internal purposes might get overwritten later. - -V
- —version
- Print the psql version and exit.
- -W
- —password
-
Forces psql to prompt for a
password before connecting to a database.psql should automatically prompt for a
password whenever the server requests password authentication.
However, currently password request detection is not totally
reliable, hence this option to force a prompt. If no password
prompt is issued and the server requires password authentication,
the connection attempt will fail.This option will remain set for the entire session, even if you
change the database connection with the meta-command
\connect. - -x
- —expanded
-
Turn on the expanded table formatting mode. This is equivalent to the
\x command. - -X,
- —no-psqlrc
-
Do not read the start-up file (neither the system-wide
psqlrc file nor the user’s
~/.psqlrc file). - -?
- —help
-
Show help about psql command line
arguments, and exit.
EXIT STATUS
psql returns 0 to the shell if it
finished normally, 1 if a fatal error of its own (out of memory,
file not found) occurs, 2 if the connection to the server went bad
and the session was not interactive, and 3 if an error occurred in a
script and the variable ON_ERROR_STOP was set.
USAGE
CONNECTING TO A DATABASE
psql is a regular
PostgreSQL client application. In order
to connect to a database you need to know the name of your target
database, the host name and port number of the server and what user
name you want to connect as. psql can be
told about those parameters via command line options, namely
-d, -h, -p, and
-U respectively. If an argument is found that does
not belong to any option it will be interpreted as the database name
(or the user name, if the database name is already given). Not all
these options are required; there are useful defaults. If you omit the host
name, psql will connect via a Unix-domain socket
to a server on the local host, or via TCP/IP to localhost on
machines that don’t have Unix-domain sockets. The default port number is
determined at compile time.
Since the database server uses the same default, you will not have
to specify the port in most cases. The default user name is your
Unix user name, as is the default database name. Note that you can’t
just connect to any database under any user name. Your database
administrator should have informed you about your access rights.
When the defaults aren’t quite right, you can save yourself
some typing by setting the environment variables
PGDATABASE, PGHOST,
PGPORT and/or PGUSER to appropriate
values. (For additional environment variables, see the documentation.) It is also convenient to have a
~/.pgpass file to avoid regularly having to type in
passwords. See the documentation for more information.
If the connection could not be made for any reason (e.g., insufficient
privileges, server is not running on the targeted host, etc.),
psql will return an error and terminate.
ENTERING SQL COMMANDS
In normal operation, psql provides a
prompt with the name of the database to which
psql is currently connected, followed by
the string =>. For example,
$ psql testdb Welcome to psql 8.1.11, the PostgreSQL interactive terminal. Type: \copyright for distribution terms \h for help with SQL commands \? for help with psql commands \g or terminate with semicolon to execute query \q to quit testdb=>
At the prompt, the user may type in SQL commands.
Ordinarily, input lines are sent to the server when a
command-terminating semicolon is reached. An end of line does not
terminate a command. Thus commands can be spread over several lines for
clarity. If the command was sent and executed without error, the results
of the command are displayed on the screen.
Whenever a command is executed, psql also polls
for asynchronous notification events generated by
LISTEN [listen(7)] and
NOTIFY [notify(7)].
META-COMMANDS
Anything you enter in psql that begins
with an unquoted backslash is a psql
meta-command that is processed by psql
itself. These commands help make
psql more useful for administration or
scripting. Meta-commands are more commonly called slash or backslash
commands.
The format of a psql command is the backslash,
followed immediately by a command verb, then any arguments. The arguments
are separated from the command verb and each other by any number of
whitespace characters.
To include whitespace into an argument you may quote it with a
single quote. To include a single quote into such an argument,
precede it by a backslash. Anything contained in single quotes is
furthermore subject to C-like substitutions for
\n (new line), \t (tab),
\digits (octal), and
\xdigits (hexadecimal).
If an unquoted argument begins with a colon (:),
it is taken as a psql variable and the value of the
variable is used as the argument instead.
Arguments that are enclosed in backquotes (`)
are taken as a command line that is passed to the shell. The
output of the command (with any trailing newline removed) is taken
as the argument value. The above escape sequences also apply in
backquotes.
Some commands take an SQL identifier (such as a
table name) as argument. These arguments follow the syntax rules
of SQL: Unquoted letters are forced to
lowercase, while double quotes («) protect letters
from case conversion and allow incorporation of whitespace into
the identifier. Within double quotes, paired double quotes reduce
to a single double quote in the resulting name. For example,
FOO»BAR»BAZ is interpreted as fooBARbaz,
and «A weird»» name» becomes A weird»
name.
Parsing for arguments stops when another unquoted backslash occurs.
This is taken as the beginning of a new meta-command. The special
sequence \\ (two backslashes) marks the end of
arguments and continues parsing SQL commands, if
any. That way SQL and
psql commands can be freely mixed on a
line. But in any case, the arguments of a meta-command cannot
continue beyond the end of the line.
The following meta-commands are defined:
- \a
-
If the current table output format is unaligned, it is switched to aligned.
If it is not unaligned, it is set to unaligned. This command is
kept for backwards compatibility. See \pset for a
more general solution. - \cd [ directory ]
-
Changes the current working directory to
directory. Without argument, changes
to the current user’s home directory.-
Tip:
To print your current working directory, use \!pwd.
-
Tip:
- \C [ title ]
-
Sets the title of any tables being printed as the result of a
query or unset any such title. This command is equivalent to
\pset title title. (The name of
this command derives from «caption», as it was
previously only used to set the caption in an
HTML table.) - \connect (or \c) [ dbname [ username ] ]
-
Establishes a connection to a new database and/or under a user
name. The previous connection is closed. If dbname is —
the current database name is assumed.If username is
omitted the current user name is assumed.As a special rule, \connect without any
arguments will connect to the default database as the default
user (as you would have gotten by starting
psql without any arguments).If the connection attempt failed (wrong user name, access
denied, etc.), the previous connection will be kept if and only
if psql is in interactive mode. When
executing a non-interactive script, processing will immediately
stop with an error. This distinction was chosen as a user
convenience against typos on the one hand, and a safety
mechanism that scripts are not accidentally acting on the wrong
database on the other hand. - \copy table
-
Performs a frontend (client) copy. This is an operation that
runs an SQL COPY [copy(7)] command, but instead of the server
reading or writing the specified file,
psql reads or writes the file and
routes the data between the server and the local file system.
This means that file accessibility and privileges are those of
the local user, not the server, and no SQL superuser
privileges are required.The syntax of the command is similar to that of the
SQL COPY [copy(7)] command. Note that, because of this,
special parsing rules apply to the \copy
command. In particular, the variable substitution rules and
backslash escapes do not apply.\copy table from stdin | stdout
reads/writes based on the command input and output respectively.
All rows are read from the same source that issued the command,
continuing until \. is read or the stream
reaches EOF. Output is sent to the same place as
command output. To read/write from
psql‘s standard input or output, use
pstdin or pstdout. This option is useful
for populating tables in-line within a SQL script file.-
Tip:
This operation is not as efficient as the SQL
COPY command because all data must pass
through the client/server connection. For large
amounts of data the SQL command may be preferable.
-
Tip:
- \copyright
-
Shows the copyright and distribution terms of
PostgreSQL. - \d [ pattern ]
- \d+ [ pattern ]
-
For each relation (table, view, index, or sequence) matching the
pattern, show all
columns, their types, the tablespace (if not the default) and any special
attributes such as NOT NULL or defaults, if
any. Associated indexes, constraints, rules, and triggers are
also shown, as is the view definition if the relation is a view.
(«Matching the pattern» is defined below.)The command form \d+ is identical, except that
more information is displayed: any comments associated with the
columns of the table are shown, as is the presence of OIDs in the
table.-
Note:
If \d is used without a
pattern argument, it is
equivalent to \dtvs which will show a list of
all tables, views, and sequences. This is purely a convenience
measure.
-
Note:
- \da [ pattern ]
-
Lists all available aggregate functions, together with the data
type they operate on. If pattern
is specified, only aggregates whose names match the pattern are shown. - \db [ pattern ]
- \db+ [ pattern ]
-
Lists all available tablespaces. If pattern
is specified, only tablespaces whose names match the pattern are shown.
If + is appended to the command name, each object
is listed with its associated permissions. - \dc [ pattern ]
-
Lists all available conversions between character-set encodings.
If pattern
is specified, only conversions whose names match the pattern are
listed. - \dC
- Lists all available type casts.
- \dd [ pattern ]
-
Shows the descriptions of objects matching the pattern, or of all visible objects if
no argument is given. But in either case, only objects that have
a description are listed.
(«Object» covers aggregates, functions, operators,
types, relations (tables, views, indexes, sequences, large
objects), rules, and triggers.) For example:=> \dd version Object descriptions Schema | Name | Object | Description ------------+---------+----------+--------------------------- pg_catalog | version | function | PostgreSQL version string (1 row)
Descriptions for objects can be created with the COMMENT [comment(7)]
SQL command. - \dD [ pattern ]
-
Lists all available domains. If pattern
is specified, only matching domains are shown. - \df [ pattern ]
- \df+ [ pattern ]
-
Lists available functions, together with their argument and
return types. If pattern
is specified, only functions whose names match the pattern are shown.
If the form \df+ is used, additional information about
each function, including language and description, is shown.-
Note:
To look up functions taking argument or returning values of a specific
type, use your pager’s search capability to scroll through the \df
output.To reduce clutter, \df does not show data type I/O
functions. This is implemented by ignoring functions that accept
or return type cstring.
-
Note:
- \dg [ pattern ]
-
Lists all database roles. If pattern is specified, only
those roles whose names match the pattern are listed.
(This command is now effectively the same as \du.) - \distvS [ pattern ]
-
This is not the actual command name: the letters
i, s, t,
v, S stand for index,
sequence, table, view, and system table, respectively. You can
specify any or all of these letters, in any order, to obtain a
listing of all the matching objects. The letter S restricts the
listing to system objects; without S, only
non-system objects are shown. If + is appended
to the command name, each object is listed with its associated
description, if any.If pattern is
specified, only objects whose names match the pattern are listed. - \dl
-
This is an alias for \lo_list, which shows a
list of large objects. - \dn [ pattern ]
- \dn+ [ pattern ]
-
Lists all available schemas (namespaces). If pattern (a regular expression)
is specified, only schemas whose names match the pattern are listed.
Non-local temporary schemas are suppressed. If +
is appended to the command name, each object is listed with its associated
permissions and description, if any. - \do [ pattern ]
-
Lists available operators with their operand and return types.
If pattern is
specified, only operators whose names match the pattern are listed. - \dp [ pattern ]
-
Produces a list of all available tables, views and sequences with their
associated access privileges.
If pattern is
specified, only tables, views and sequences whose names match the pattern are listed.The commands GRANT and
REVOKE are used to set access privileges.
See GRANT [grant(7)]
for more information. - \dT [ pattern ]
- \dT+ [ pattern ]
-
Lists all data types or only those that match pattern. The command form
\dT+ shows extra information. - \du [ pattern ]
- Lists all database roles, or only those that match pattern.
- \edit (or \e) [ filename ]
-
If filename is
specified, the file is edited; after the editor exits, its
content is copied back to the query buffer. If no argument is
given, the current query buffer is copied to a temporary file
which is then edited in the same fashion.The new query buffer is then re-parsed according to the normal
rules of psql, where the whole buffer
is treated as a single line. (Thus you cannot make scripts this
way. Use \i for that.) This means also that
if the query ends with (or rather contains) a semicolon, it is
immediately executed. In other cases it will merely wait in the
query buffer.-
Tip:
psql searches the environment
variables PSQL_EDITOR, EDITOR, and
VISUAL (in that order) for an editor to use. If
all of them are unset, vi is used on Unix
systems, notepad.exe on Windows systems.
-
Tip:
- \echo text [ … ]
-
Prints the arguments to the standard output, separated by one
space and followed by a newline. This can be useful to
intersperse information in the output of scripts. For example:=> \echo `date` Tue Oct 26 21:40:57 CEST 1999
If the first argument is an unquoted -n the trailing
newline is not written.-
Tip:
If you use the \o command to redirect your
query output you may wish to use \qecho
instead of this command.
-
Tip:
- \encoding [ encoding ]
-
Sets the client character set encoding. Without an argument, this command
shows the current encoding. - \f [ string ]
-
Sets the field separator for unaligned query output. The default
is the vertical bar (|). See also
\pset for a generic way of setting output
options. - \g [ { filename | |command } ]
-
Sends the current query input buffer to the server and
optionally stores the query’s output in filename or pipes the output
into a separate Unix shell executing command. A bare
\g is virtually equivalent to a semicolon. A
\g with argument is a «one-shot»
alternative to the \o command. - \help (or \h) [ command ]
-
Gives syntax help on the specified SQL
command. If command
is not specified, then psql will list
all the commands for which syntax help is available. If
command is an
asterisk (*), then syntax help on all
SQL commands is shown.-
Note:
To simplify typing, commands that consists of several words do
not have to be quoted. Thus it is fine to type \help
alter table.
-
Note:
- \H
-
Turns on HTML query output format. If the
HTML format is already on, it is switched
back to the default aligned text format. This command is for
compatibility and convenience, but see \pset
about setting other output options. - \i filename
-
Reads input from the file filename and executes it as
though it had been typed on the keyboard.-
Note:
If you want to see the lines on the screen as they are read you
must set the variable ECHO to
all.
-
Note:
- \l (or \list)
- \l+ (or \list+)
-
List the names, owners, and character set encodings of all the databases in
the server. If + is appended to the command
name, database descriptions are also displayed. - \lo_export loid filename
-
Reads the large object with OID loid from the database and
writes it to filename. Note that this is
subtly different from the server function
lo_export, which acts with the permissions
of the user that the database server runs as and on the server’s
file system.-
Tip:
Use \lo_list to find out the large object’s
OID.
-
Tip:
- \lo_import filename [ comment ]
-
Stores the file into a PostgreSQL
large object. Optionally, it associates the given
comment with the object. Example:foo=> \lo_import '/home/peter/pictures/photo.xcf' 'a picture of me' lo_import 152801
The response indicates that the large object received object ID
152801 which one ought to remember if one wants to access the
object ever again. For that reason it is recommended to always
associate a human-readable comment with every object. Those can
then be seen with the \lo_list command.Note that this command is subtly different from the server-side
lo_import because it acts as the local user
on the local file system, rather than the server’s user and file
system. - \lo_list
-
Shows a list of all PostgreSQL
large objects currently stored in the database,
along with any comments provided for them. - \lo_unlink loid
-
Deletes the large object with OID
loid from the
database.-
Tip:
Use \lo_list to find out the large object’s
OID.
-
Tip:
- \o [ {filename | |command} ]
-
Saves future query results to the file filename or pipes future results
into a separate Unix shell to execute command. If no arguments are
specified, the query output will be reset to the standard output.«Query results» includes all tables, command
responses, and notices obtained from the database server, as
well as output of various backslash commands that query the
database (such as \d), but not error
messages.-
Tip:
To intersperse text output in between query results, use
\qecho.
-
Tip:
- \p
- Print the current query buffer to the standard output.
- \pset parameter [ value ]
-
This command sets options affecting the output of query result
tables. parameter
describes which option is to be set. The semantics of
value depend
thereon.Adjustable printing options are:
-
- format
-
Sets the output format to one of unaligned,
aligned, html,
latex, or troff-ms.
Unique abbreviations are allowed. (That would mean one letter
is enough.)«Unaligned» writes all columns of a row on a
line, separated by the currently active field separator. This
is intended to create output that might be intended to be read
in by other programs (tab-separated, comma-separated).
«Aligned» mode is the standard, human-readable,
nicely formatted text output that is default. The
«HTML» and
«LaTeX» modes put out tables that are intended to
be included in documents using the respective mark-up
language. They are not complete documents! (This might not be
so dramatic in HTML, but in LaTeX you must
have a complete document wrapper.) - border
-
The second argument must be a number. In general, the higher
the number the more borders and lines the tables will have,
but this depends on the particular format. In
HTML mode, this will translate directly
into the border=… attribute, in the
others only values 0 (no border), 1 (internal dividing lines),
and 2 (table frame) make sense. - expanded (or x)
-
Toggles between regular and expanded format. When expanded
format is enabled, query results are displayed in two
columns, with the column name on the left and the data on
the right. This mode is useful if the data wouldn’t fit on the
screen in the normal «horizontal» mode.Expanded mode is supported by all four output formats.
- null
-
The second argument is a string that should be printed
whenever a column is null. The default is not to print
anything, which can easily be mistaken for, say, an empty
string. Thus, one might choose to write \pset null
‘(null)’. - fieldsep
-
Specifies the field separator to be used in unaligned output
mode. That way one can create, for example, tab- or
comma-separated output, which other programs might prefer. To
set a tab as field separator, type \pset fieldsep
‘\t’. The default field separator is
‘|’ (a vertical bar). - footer
-
Toggles the display of the default footer (x
rows). - numericlocale
-
Toggles the display of a locale-aware character to separate groups
of digits to the left of the decimal marker. It also enables
a locale-aware decimal marker. - recordsep
-
Specifies the record (line) separator to use in unaligned
output mode. The default is a newline character. - tuples_only (or t)
-
Toggles between tuples only and full display. Full display may
show extra information such as column headers, titles, and
various footers. In tuples only mode, only actual table data
is shown. - title [ text ]
-
Sets the table title for any subsequently printed tables. This
can be used to give your output descriptive tags. If no
argument is given, the title is unset. - tableattr (or T) [ text ]
-
Allows you to specify any attributes to be placed inside the
HTML table tag. This
could for example be cellpadding or
bgcolor. Note that you probably don’t want
to specify border here, as that is already
taken care of by \pset border. - pager
-
Controls use of a pager for query and psql
help output. If the environment variable PAGER
is set, the output is piped to the specified program.
Otherwise a platform-dependent default (such as
more) is used.When the pager is off, the pager is not used. When the pager
is on, the pager is used only when appropriate, i.e. the
output is to a terminal and will not fit on the screen.
(psql does not do a perfect job of estimating
when to use the pager.) \pset pager turns the
pager on and off. Pager can also be set to always,
which causes the pager to be always used.
-
Illustrations on how these different formats look can be seen in
the Examples [psql(1)] section.
-
Tip:
There are various shortcut commands for \pset. See
\a, \C, \H,
\t, \T, and \x.
-
Note:
It is an error to call \pset without
arguments. In the future this call might show the current status
of all printing options.
- \q
- Quits the psql program.
- \qecho text [ … ]
-
This command is identical to \echo except
that the output will be written to the query output channel, as
set by \o. - \r
- Resets (clears) the query buffer.
- \s [ filename ]
-
Print or save the command line history to filename. If filename is omitted, the history
is written to the standard output. This option is only available
if psql is configured to use the
GNU Readline library. - \set [ name [ value [ … ] ] ]
-
Sets the internal variable name to value or, if more than one value
is given, to the concatenation of all of them. If no second
argument is given, the variable is just set with no value. To
unset a variable, use the \unset command.Valid variable names can contain characters, digits, and
underscores. See the section Variables [psql(1)] below for details.
Variable names are case-sensitive.Although you are welcome to set any variable to anything you
want, psql treats several variables
as special. They are documented in the section about variables.-
Note:
This command is totally separate from the SQL
command SET [set(7)].
-
Note:
- \t
-
Toggles the display of output column name headings and row count
footer. This command is equivalent to \pset
tuples_only and is provided for convenience. - \T table_options
-
Allows you to specify attributes to be placed within the
table tag in HTML tabular
output mode. This command is equivalent to \pset
tableattr table_options. - \timing
- Toggles a display of how long each SQL statement takes, in milliseconds.
- \w {filename | |command}
-
Outputs the current query buffer to the file filename or pipes it to the Unix
command command. - \x
-
Toggles expanded table formatting mode. As such it is equivalent to
\pset expanded. - \z [ pattern ]
-
Produces a list of all available tables, views and sequences with their
associated access privileges.
If a pattern is
specified, only tables,views and sequences whose names match the pattern are listed.The commands GRANT and
REVOKE are used to set access privileges.
See GRANT [grant(7)] for
more information.This is an alias for \dp («display
privileges»). - \! [ command ]
-
Escapes to a separate Unix shell or executes the Unix command
command. The
arguments are not further interpreted, the shell will see them
as is. - \?
- Shows help information about the backslash commands.
The various \d commands accept a pattern parameter to specify the
object name(s) to be displayed. * means «any
sequence of characters» and ? means «any single
character». (This notation is comparable to Unix shell file name
patterns.) Advanced users can also use regular-expression
notations such as character classes, for example [0-9]
to match «any digit». To make any of these
pattern-matching characters be interpreted literally, surround it
with double quotes.
A pattern that contains an (unquoted) dot is interpreted as a schema
name pattern followed by an object name pattern. For example,
\dt foo*.bar* displays all tables in schemas whose name
starts with foo and whose table name
starts with bar. If no dot appears, then the pattern
matches only objects that are visible in the current schema search path.
Whenever the pattern parameter
is omitted completely, the \d commands display all objects
that are visible in the current schema search path. To see all objects
in the database, use the pattern *.*.
ADVANCED FEATURES
VARIABLES
psql provides variable substitution
features similar to common Unix command shells.
Variables are simply name/value pairs, where the value
can be any string of any length. To set variables, use the
psql meta-command
\set:
testdb=> \set foo bar
sets the variable foo to the value
bar. To retrieve the content of the variable, precede
the name with a colon and use it as the argument of any slash
command:
testdb=> \echo :foo bar
-
Note:
The arguments of \set are subject to the same
substitution rules as with other commands. Thus you can construct
interesting references such as \set :foo
‘something’ and get «soft links» or
«variable variables» of Perl
or PHP fame,
respectively. Unfortunately (or fortunately?), there is no way to do
anything useful with these constructs. On the other hand,
\set bar :foo is a perfectly valid way to copy a
variable.
If you call \set without a second argument, the
variable is set, with an empty string as value. To unset (or delete) a
variable, use the command \unset.
psql‘s internal variable names can
consist of letters, numbers, and underscores in any order and any
number of them. A number of these variables are treated specially
by psql. They indicate certain option
settings that can be changed at run time by altering the value of
the variable or represent some state of the application. Although
you can use these variables for any other purpose, this is not
recommended, as the program behavior might grow really strange
really quickly. By convention, all specially treated variables
consist of all upper-case letters (and possibly numbers and
underscores). To ensure maximum compatibility in the future, avoid
using such variable names for your own purposes. A list of all specially
treated variables follows.
- AUTOCOMMIT
-
When on (the default), each SQL command is automatically
committed upon successful completion. To postpone commit in this
mode, you must enter a BEGIN or START
TRANSACTION SQL command. When off or unset, SQL
commands are not committed until you explicitly issue
COMMIT or END. The autocommit-off
mode works by issuing an implicit BEGIN for you, just
before any command that is not already in a transaction block and
is not itself a BEGIN or other transaction-control
command, nor a command that cannot be executed inside a transaction
block (such as VACUUM).-
Note:
In autocommit-off mode, you must explicitly abandon any failed
transaction by entering ABORT or ROLLBACK.
Also keep in mind that if you exit the session
without committing, your work will be lost.
-
Note:
The autocommit-on mode is PostgreSQL’s traditional
behavior, but autocommit-off is closer to the SQL spec. If you
prefer autocommit-off, you may wish to set it in the system-wide
psqlrc file or your
~/.psqlrc file.
-
Note:
- DBNAME
-
The name of the database you are currently connected to. This is
set every time you connect to a database (including program
start-up), but can be unset. - ECHO
-
If set to all, all lines
entered from the keyboard or from a script are written to the standard output
before they are parsed or executed. To select this behavior on program
start-up, use the switch -a. If set to
queries,
psql merely prints all queries as
they are sent to the server. The switch for this is
-e. - ECHO_HIDDEN
-
When this variable is set and a backslash command queries the
database, the query is first shown. This way you can study the
PostgreSQL internals and provide
similar functionality in your own programs. (To select this behavior
on program start-up, use the switch -E.) If you set
the variable to the value noexec, the queries are
just shown but are not actually sent to the server and executed. - ENCODING
- The current client character set encoding.
- HISTCONTROL
-
If this variable is set to ignorespace,
lines which begin with a space are not entered into the history
list. If set to a value of ignoredups, lines
matching the previous history line are not entered. A value of
ignoreboth combines the two options. If
unset, or if set to any other value than those above, all lines
read in interactive mode are saved on the history list.-
Note:
This feature was shamelessly plagiarized from
Bash.
-
Note:
- HISTFILE
-
The file name that will be used to store the history list. The default
value is ~/.psql_history. For example, putting\set HISTFILE ~/.psql_history- :DBNAME
in ~/.psqlrc will cause
psql to maintain a separate history for
each database.-
Note:
This feature was shamelessly plagiarized from
Bash.
-
Note:
- HISTSIZE
-
The number of commands to store in the command history. The
default value is 500.-
Note:
This feature was shamelessly plagiarized from
Bash.
-
Note:
- HOST
-
The database server host you are currently connected to. This is
set every time you connect to a database (including program
start-up), but can be unset. - IGNOREEOF
-
If unset, sending an EOF character (usually
Control+D)
to an interactive session of psql
will terminate the application. If set to a numeric value,
that many EOF characters are ignored before the
application terminates. If the variable is set but has no
numeric value, the default is 10.-
Note:
This feature was shamelessly plagiarized from
Bash.
-
Note:
- LASTOID
-
The value of the last affected OID, as returned from an
INSERT or lo_insert
command. This variable is only guaranteed to be valid until
after the result of the next SQL command has
been displayed. - ON_ERROR_ROLLBACK
-
When on, if a statement in a transaction block
generates an error, the error is ignored and the transaction
continues. When interactive, such errors are only
ignored in interactive sessions, and not when reading script
files. When off (the default), a statement in a
transaction block that generates an error aborts the entire
transaction. The on_error_rollback-on mode works by issuing an
implicit SAVEPOINT for you, just before each command
that is in a transaction block, and rolls back to the savepoint
on error. - ON_ERROR_STOP
-
By default, if non-interactive scripts encounter an error, such
as a malformed SQL command or internal
meta-command, processing continues. This has been the
traditional behavior of psql but it
is sometimes not desirable. If this variable is set, script
processing will immediately terminate. If the script was called
from another script it will terminate in the same fashion. If
the outermost script was not called from an interactive
psql session but rather using the
-f option, psql will
return error code 3, to distinguish this case from fatal error
conditions (error code 1). - PORT
-
The database server port to which you are currently connected.
This is set every time you connect to a database (including
program start-up), but can be unset. - PROMPT1
- PROMPT2
- PROMPT3
-
These specify what the prompts psql
issues should look like. See Prompting [psql(1)] below. - QUIET
-
This variable is equivalent to the command line option
-q. It is probably not too useful in
interactive mode. - SINGLELINE
-
This variable is equivalent to the command line option
-S. - SINGLESTEP
-
This variable is equivalent to the command line option
-s. - USER
-
The database user you are currently connected as. This is set
every time you connect to a database (including program
start-up), but can be unset. - VERBOSITY
-
This variable can be set to the values default,
verbose, or terse to control the verbosity
of error reports.
SQL INTERPOLATION
An additional useful feature of psql
variables is that you can substitute («interpolate»)
them into regular SQL statements. The syntax for
this is again to prepend the variable name with a colon
(:).
testdb=> \set foo 'my_table' testdb=> SELECT * FROM :foo;
would then query the table my_table. The value of
the variable is copied literally, so it can even contain unbalanced
quotes or backslash commands. You must make sure that it makes sense
where you put it. Variable interpolation will not be performed into
quoted SQL entities.
A popular application of this facility is to refer to the last
inserted OID in subsequent statements to build a
foreign key scenario. Another possible use of this mechanism is to
copy the contents of a file into a table column. First load the file into a
variable and then proceed as above.
testdb=> \set content '\'' `cat my_file.txt` '\'' testdb=> INSERT INTO my_table VALUES (:content);
One possible problem with this approach is that my_file.txt
might contain single quotes. These need to be escaped so that
they don’t cause a syntax error when the second line is processed. This
could be done with the program sed:
testdb=> \set content '\'' `sed -e "s/'/\\\\\\'/g" < my_file.txt` '\''
Observe the correct number of backslashes (6)! It works
this way: After psql has parsed this
line, it passes sed -e «s/’/\\\’/g» < my_file.txt
to the shell. The shell will do its own thing inside the double
quotes and execute sed with the arguments
-e and s/’/\\’/g. When
sed parses this it will replace the two
backslashes with a single one and then do the substitution. Perhaps
at one point you thought it was great that all Unix commands use the
same escape character. And this is ignoring the fact that you might
have to escape all backslashes as well because
SQL text constants are also subject to certain
interpretations. In that case you might be better off preparing the
file externally.
Since colons may legally appear in SQL commands, the following rule
applies: the character sequence
«:name» is not changed unless «name» is the name
of a variable that is currently set. In any case you can escape
a colon with a backslash to protect it from substitution. (The
colon syntax for variables is standard SQL for
embedded query languages, such as ECPG.
The colon syntax for array slices and type casts are
PostgreSQL extensions, hence the
conflict.)
PROMPTING
The prompts psql issues can be customized
to your preference. The three variables PROMPT1,
PROMPT2, and PROMPT3 contain strings
and special escape sequences that describe the appearance of the
prompt. Prompt 1 is the normal prompt that is issued when
psql requests a new command. Prompt 2 is
issued when more input is expected during command input because the
command was not terminated with a semicolon or a quote was not closed.
Prompt 3 is issued when you run an SQL
COPY command and you are expected to type in the
row values on the terminal.
The value of the selected prompt variable is printed literally,
except where a percent sign (%) is encountered.
Depending on the next character, certain other text is substituted
instead. Defined substitutions are:
- %M
-
The full host name (with domain name) of the database server,
or [local] if the connection is over a Unix
domain socket, or
[local:/dir/name],
if the Unix domain socket is not at the compiled in default
location. - %m
-
The host name of the database server, truncated at the
first dot, or [local] if the connection is
over a Unix domain socket. - %>
- The port number at which the database server is listening.
- %n
-
The database session user name. (The expansion of this
value might change during a database session as the result
of the command SET SESSION
AUTHORIZATION.) - %/
- The name of the current database.
- %~
-
Like %/, but the output is ~
(tilde) if the database is your default database. - %#
-
If the session user is a database superuser, then a
#, otherwise a >.
(The expansion of this value might change during a database
session as the result of the command SET SESSION
AUTHORIZATION.) - %R
-
In prompt 1 normally =, but ^ if
in single-line mode, and ! if the session is
disconnected from the database (which can happen if
\connect fails). In prompt 2 the sequence is
replaced by -, *, a single quote,
a double quote, or a dollar sign, depending on whether
psql expects more input because the
command wasn’t terminated yet, because you are inside a
/* … */ comment, or because you are inside
a quoted or dollar-escaped string. In prompt 3 the sequence doesn’t
produce anything. - %x
-
Transaction status: an empty string when not in a transaction
block, or * when in a transaction block, or
! when in a failed transaction block, or ?
when the transaction state is indeterminate (for example, because
there is no connection). - %digits
- The character with the indicated octal code is substituted.
- %:name:
-
The value of the psql variable
name. See the
section Variables [psql(1)] for details. - %`command`
-
The output of command, similar to ordinary
«back-tick» substitution. - %[ … %]
-
Prompts may contain terminal control characters which, for
example, change the color, background, or style of the prompt
text, or change the title of the terminal window. In order for
the line editing features of Readline to work properly, these
non-printing control characters must be designated as invisible
by surrounding them with %[ and
%]. Multiple pairs of these may occur within
the prompt. For example,testdb=> \set PROMPT1 '%[%033[1;33;40m%]%n@%/%R%[%033[0m%#%] '
results in a boldfaced (1;) yellow-on-black
(33;40) prompt on VT100-compatible, color-capable
terminals.
To insert a percent sign into your prompt, write
%%. The default prompts are
‘%/%R%# ‘ for prompts 1 and 2, and
‘>> ‘ for prompt 3.
-
Note:
This feature was shamelessly plagiarized from
tcsh.
COMMAND-LINE EDITING
psql supports the Readline
library for convenient line editing and retrieval. The command
history is automatically saved when psql
exits and is reloaded when
psql starts up. Tab-completion is also
supported, although the completion logic makes no claim to be an
SQL parser. If for some reason you do not like the tab completion, you
can turn it off by putting this in a file named
.inputrc in your home directory:
$if psql set disable-completion on $endif
(This is not a psql but a
Readline feature. Read its documentation
for further details.)
ENVIRONMENT
- PAGER
-
If the query results do not fit on the screen, they are piped
through this command. Typical values are
more or less. The default
is platform-dependent. The use of the pager can be disabled by
using the \pset command. - PGDATABASE
- Default connection database
- PGHOST
- PGPORT
- PGUSER
- Default connection parameters
- PSQL_EDITOR
- EDITOR
- VISUAL
-
Editor used by the \e command. The variables
are examined in the order listed; the first that is set is used. - SHELL
- Command executed by the \! command.
- TMPDIR
-
Directory for storing temporary files. The default is
/tmp.
FILES
- *
-
Before starting up, psql attempts to
read and execute commands from the system-wide
psqlrc file and the user’s
~/.psqlrc file.
(On Windows, the user’s startup file is named
%APPDATA%\postgresql\psqlrc.conf.)
See PREFIX/share/psqlrc.sample
for information on setting up the system-wide file. It could be used
to set up the client or the server to taste (using the \set
and SET commands). - *
-
Both the system-wide psqlrc file and the user’s
~/.psqlrc file can be made version-specific
by appending a dash and the PostgreSQL
release number, for example ~/.psqlrc-8.1.11.
A matching version-specific file will be read in preference to a
non-version-specific file. - *
-
The command-line history is stored in the file
~/.psql_history, or
%APPDATA%\postgresql\psql_history on Windows.
NOTES
- *
-
In an earlier life psql allowed the
first argument of a single-letter backslash command to start
directly after the command, without intervening whitespace. For
compatibility this is still supported to some extent,
but we are not going to explain the details here as this use is
discouraged. If you get strange messages, keep this in mind.
For exampletestdb=> \foo Field separator is "oo".
which is perhaps not what one would expect.
- *
-
psql only works smoothly with servers
of the same version. That does not mean other combinations will
fail outright, but subtle and not-so-subtle problems might come
up. Backslash commands are particularly likely to fail if the
server is of a different version.
NOTES FOR WINDOWS USERS
psql is built as a «console
application». Since the Windows console windows use a different
encoding than the rest of the system, you must take special care
when using 8-bit characters within psql.
If psql detects a problematic
console code page, it will warn you at startup. To change the
console code page, two things are necessary:
- *
-
Set the code page by entering cmd.exe /c chcp
1252. (1252 is a code page that is appropriate for
German; replace it with your value.) If you are using Cygwin,
you can put this command in /etc/profile. - *
-
Set the console font to «Lucida Console», because the
raster font does not work with the ANSI code page.
EXAMPLES
The first example shows how to spread a command over several lines of
input. Notice the changing prompt:
testdb=> CREATE TABLE my_table ( testdb(> first integer not null default 0, testdb(> second text) testdb-> ; CREATE TABLE
Now look at the table definition again:
testdb=> \d my_table Table "my_table" Attribute | Type | Modifier -----------+---------+-------------------- first | integer | not null default 0 second | text |
Now we change the prompt to something more interesting:
testdb=> \set PROMPT1 '%n@%m %~%R%# ' peter@localhost testdb=>
Let’s assume you have filled the table with data and want to take a
look at it:
peter@localhost testdb=> SELECT * FROM my_table; first | second -------+-------- 1 | one 2 | two 3 | three 4 | four (4 rows)
You can display tables in different ways by using the
\pset command:
peter@localhost testdb=> \pset border 2 Border style is 2. peter@localhost testdb=> SELECT * FROM my_table; +-------+--------+ | first | second | +-------+--------+ | 1 | one | | 2 | two | | 3 | three | | 4 | four | +-------+--------+ (4 rows) peter@localhost testdb=> \pset border 0 Border style is 0. peter@localhost testdb=> SELECT * FROM my_table; first second ----- ------ 1 one 2 two 3 three 4 four (4 rows) peter@localhost testdb=> \pset border 1 Border style is 1. peter@localhost testdb=> \pset format unaligned Output format is unaligned. peter@localhost testdb=> \pset fieldsep "," Field separator is ",". peter@localhost testdb=> \pset tuples_only Showing only tuples. peter@localhost testdb=> SELECT second, first FROM my_table; one,1 two,2 three,3 four,4
Alternatively, use the short commands:
peter@localhost testdb=> \a \t \x Output format is aligned. Tuples only is off. Expanded display is on. peter@localhost testdb=> SELECT * FROM my_table; -[ RECORD 1 ]- first | 1 second | one -[ RECORD 2 ]- first | 2 second | two -[ RECORD 3 ]- first | 3 second | three -[ RECORD 4 ]- first | 4 second | four
SEE ALSO
Environment Variables (the documentation)
Index
- NAME
- SYNOPSIS
- DESCRIPTION
- OPTIONS
- EXIT STATUS
- USAGE
-
- CONNECTING TO A DATABASE
- ENTERING SQL COMMANDS
- META-COMMANDS
- ADVANCED FEATURES
- VARIABLES
- SQL INTERPOLATION
- PROMPTING
- COMMAND-LINE EDITING
- ENVIRONMENT
- FILES
- NOTES
- NOTES FOR WINDOWS USERS
- EXAMPLES
- SEE ALSO
postgres
You’ve installed PostgreSQL. Now what? I assume you’ve been given a task that
uses psql
and you want to learn the absolute minimum to
get the job done.
This is both a brief tutorial and a
quick reference for the absolute least you need to know about psql
.
I assume you’re familiar with the command line and have a rough idea about
what database administration tasks, but aren’t familiar with how to
use psql
to do the basics.
View on GitHub Pages or directly on GitHub
The PostgreSQL documentation is incredibly
well written and thorough, but frankly, I didn’t know where to start reading. This
is my answer to that problem.
If you have any complaints or suggestions please let me know by
sending your feedback to tomcampbell@gmail.com.
It shows how to do the following at the psql
prompt:
- Start and quit
psql
- Get help
- Get information about databases
- Create databases
- CREATE TABLEs
- INSERT, or add records to a table
- SELECT, to do simple queries
- Reference pointing to the official PostgreSQL documentation
If you don’t have access to a live PostgreSQL installation at the moment we still have your back.
You can follow through the examples and the output is shown as if you
did type everything out.
The psql command line utility
Many administrative tasks can or should be done on your local machine,
even though if database lives on the cloud.
You can do some of them through a visual user interface, but that’s not covered here.
Knowing how to perform these operations on the command line means you can script them,
and scripting means you can automate tests, check errors, and do data entry on the command line.
This section isn’t a full cheat sheet for psql
.
It covers the most common operations and shows them roughly in sequence,
as you’d use them in a typical work session.
Starting and quitting the psql interactive terminal |
---|
Command-line prompts for psql |
Quitting psql |
Opening a connection locally |
Opening a connection remotely |
Using the psql prompt |
Getting information about databases |
\h Help |
\l List databases |
\c Connect to a database |
\dt Display tables |
\d and \d+ Display columns (field names) of a table |
\du Display user roles |
Creating and using tables and records |
Creating a database |
Creating a table (CREATE TABLE) |
Adding a record (INSERT INTO) |
Inserting several records at once (INSERT INTO) |
Adding only specific fields from a record |
Doing a simple query–get a list of records (SELECT) |
Maintenance and operations |
Timing |
Watch |
Maintenance |
What you need to know
Before using this section, you’ll need:
- The user name and password for your PostgreSQL database
- The IP address of your remote instance
Command-line prompts on the operating system
The $
starting a command line in the examples below represents your operating system prompt.
Prompts are configurable so it may well not look like this.
On Windows it might look like C:\Program Files\PostgreSQL>
but Windows prompts are also configurable.
$ psql -U sampleuser -h localhost
A line starting with #
represents a comment. Same for everything to the right of a #
.
If you accidentally type it or copy and paste it in, don’t worry. Nothing will happen.
This worked to connect to Postgres on DigitalOcean
# -U is the username (it will appear in the \l command)
# -h is the name of the machine where the server is running.
# -p is the port where the database listens to connections. Default is 5432.
# -d is the name of the database to connect to. I think DO generated this for me, or maybe PostgreSQL.
# Password when asked is csizllepewdypieiib
$ psql -U doadmin -h production-sfo-test1-do-user-4866002-0.db.ondigitalocean.com -p 25060 -d mydb
# Open a database in a remote location.
$ psql -U sampleuser -h production-sfo-test1-do-user-4866002-0.db.ondigitalocean.com -p 21334
Using psql
You’ll use psql
(aka the PostgreSQL interactive terminal) most of all because it’s used to create databases and tables, show information about tables, and even to enter information (records) into the database.
Quitting pqsql
Before we learn anything else, here’s how to quit psql
and return to the operating system prompt.
You type backslash, the letter q
, and then you press the Enter or return key.
# Press enter after typing \q
# Remember this is backslash, not forward slash
postgres=# \q
This takes you back out to the operating system prompt.
Opening a connection locally
A common case during development is opening a connection to a local database (one on your own machine).
Run psql
with -U
(for user name) followed by the name of the database, postgres
in this example:
# Log into Postgres as the user named postgres
$ psql -U postgres
Opening a connection remotely
To connect your remote PostgreSQL instance from your local machine, use psql
at your operating system command line.
Here’s a typical connection.
# -U is the username (it will appear in the \l command)
# -h is the name of the machine where the server is running.
# -p is the port where the database listens to connections. Default is 5432.
# -d is the name of the database to connect to. I think DO generated this for me, or maybe PostgreSQL.
$ psql -U doadmin -h production-sfo-test1-do-user-4866002-0.db.ondigitalocean.com -p 25060 -d defaultdb
Here you’d enter the password. In case someone is peering over your shoulder, the characters are hidden. After you’ve entered your information properly you’ll get this message (truncated for clarity):
Looking at the psql prompt
A few things appear, then the psql
prompt is displayed.
The name of the current database appears before the prompt.
psql (11.1, server 11.0)
Type "help" for help.
postgres=#
At this point you’re expected to type commands and parameters into the command line.
psql vs SQL commands
psql
has two different kinds of commands. Those starting with a backslash
are for psql
itself, as illustrated by the use of \q
to quit.
Those starting with valid SQL are of course interactive SQL used to
create and modify PostgreSQL databases.
Warning: SQL commands end with a semicolon!
One gotcha is that almost all SQL commands you enter into psql
must end in a semicolon.
- For example,suppose you want to remove a table named
sample_property_5
. You’d enter this command:
postgres=# DROP TABLE "sample_property_5";
It’s easy to forget. If you do forget the semicolon, you’ll see this perplexing prompt.
Note that a [
has been inserted before the username portion of the prompt, and another
prompt appears below it:
[postgres=# DROP TABLE "sample_property_5"
postgres=#
When you do, just remember to finish it off with that semicolon:
[postgres=# DROP TABLE "sample_property_5"
postgres=# ;
Scrolling through the command history
- Use the up and down arrow keys to move backwards and forwards through the command history.
Getting information about databases
These aren’t SQL commands so just press Enter after them. Remember that:
- When there’s more output than fits the screen, it pauses. Press space to continue
- If you want to halt the output, press
q
.
\h Help
# Get help. Note it's a backslash, not a forward slash.
postgres=# \h
You’ll get a long list of commands, then output is paused:
Available help:
ABORT CREATE USER
...
ALTER AGGREGATE CREATE USER MAPPING
ALTER PROCEDURE DROP INDEX
:
- Press space to continue, or
q
to stop the output.
You can get help on a particular item by listing it after the \h
command.
- For example, to get help on
DROP TABLE
:
postgres=# \h drop table
You’ll get help on just that item:
Command: DROP TABLE
Description: remove a table
Syntax:
DROP TABLE [ IF EXISTS ] name [, ...] [ CASCADE | RESTRICT ]
\l List databases
What most people think of as a database (say, a list of customers) is actually a table. A database is a set of tables, information about those tables, information about users and their permissions, and much more. Some of these databases (and the tables within) are updated automatically by PostgreSQL as you use them.
To get a list of all databases:
postgres=# \l
List of databases
Name | Owner | Encoding | Collate | Ctype | Access privileges
-----------+----------+----------+-------------+-------------+-----------------------
visitor | tom | UTF8 | en_US.UTF-8 | en_US.UTF-8 |
markets | tom | UTF8 | en_US.UTF-8 | en_US.UTF-8 |
postgres | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 |
template0 | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 | =c/postgres +
| | | | | postgres=CTc/postgres
template1 | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 | =c/postgres +
| | | | | postgres=CTc/postgres
tom | tom | UTF8 | en_US.UTF-8 | en_US.UTF-8 |
You can get info on a single database by following the \l
prompt with its name.
- For example, to view information about the
template0
database:
postgres=# \l template0
The output would be:
postgres=# \l
List of databases
Name | Owner | Encoding | Collate | Ctype | Access privileges
-----------+----------+----------+-------------+-------------+-----------------------
template0 | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 | =c/postgres +
| | | | | postgres=CTc/postgres
\l+ List databases with size, tablespace, and description
To get additional information on the space consumed by database tables
and comments describing those tables, use \l+
:
postgres=# \l+
\x Expand/narrow table lists
Use \x
(X for eXpanded listing) to control
whether table listings use a wide or narrow format.
Command | Effect |
---|---|
\x off |
Show table listings in wide format |
\x on |
Show table listings in narrow format |
\x |
Reverse the previous state |
\x auto |
Use terminal to determine format |
Example: Here’s an expanded listing:
/* List all databases. */
postgres=# \l
List of databases
Name | Owner | Encoding | Collate | Ctype | Access privileges
-----------+----------+----------+-------------+-------------+-----------------------
foo | tom | UTF8 | en_US.UTF-8 | en_US.UTF-8 |
foobarino | tom | UTF8 | en_US.UTF-8 | en_US.UTF-8 |
postgres | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 |
template0 | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 | =c/postgres +
| | | | | postgres=CTc/postgres
template1 | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 | =c/postgres +
| | | | | postgres=CTc/postgres
tom | tom | UTF8 | en_US.UTF-8 | en_US.UTF-8 |
(6 rows)
Use \x on
for narrower listings:
/* Turn on narrow listings. */
postgres=# \x on
postgres=# \l
-[ RECORD 1 ]-----+----------------------
Name | foo
Owner | tom
Encoding | UTF8
Collate | en_US.UTF-8
Ctype | en_US.UTF-8
Access privileges |
-[ RECORD 2 ]-----+----------------------
Name | foobarino
Owner | tom
Encoding | UTF8
Collate | en_US.UTF-8
Ctype | en_US.UTF-8
Access privileges |
-[ RECORD 3 ]-----+----------------------
Name | postgres
Owner | postgres
Encoding | UTF8
Collate | en_US.UTF-8
Ctype | en_US.UTF-8
Access privileges |
\c Connect to a database
To see what’s inside a database, connect to it using \c
followed by the database name.
The prompt changes to match the name of the database you’re connecting to.
(The one named postgres
is always interesting.) Here we’re connecting to the one named
markets
:
postgres=# \c markets
psql (11.1, server 11.0)
You are now connected to database "markets" as user "tom".
markets=#
\dt Display tables
- Use
\dt
to list all the tables (technically, relations) in the database:
markets=# \dt
List of relations
Schema | Name | Type | Owner
--------+------------------------------+-------+----------
public | addresspool | table | tom
public | adlookup | table | tom
public | bidactivitysummary | table | tom
public | bidactivitydetail | table | tom
public | customerpaymentsummary | table | tom
...
- If you choose a database such as
postgres
there could be many tables.
Remember you can pause output by pressing space or halt it by pressingq
.
\d and \d+ Display columns (field names) of a table
To view the schema of a table, use \d
followed by the name of the table.
- To view the schema of a table named
customerpaymentsummary
, enter
markets=# \d customerpaymentsummary
Table "public.customerpaymentsummary"
Column | Type | Collation | Nullable | Default
------------------------------+-----------------------------+-----------+----------+--------
usersysid | integer | | not null |
paymentattemptsall | integer | | |
paymentattemptsmailin | integer | | |
paymentattemptspaypal | integer | | |
paymentattemptscreditcard | integer | | |
paymentacceptedoutagecredit | integer | | |
totalmoneyin | numeric(12,2) | | |
updatewhen1 | timestamp without time zone | | |
updatewhen2 | timestamp without time zone | | |
To view more detailed information on a table, use \d+
:
markets=# \d customerpaymentsummary
Table "public.customerpaymentsummary"
Column | Type | Collation | Nullable | Default | Storage | Stats target |
------------------------------+-----------------------------+-----------+----------+---------+---------+---------------
usersysid | integer | | not null | | plain | |
paymentattemptsall | integer | | | | plain | |
paymentattemptsmailin | integer | | | | plain | |
paymentattemptspaypal | integer | | | | plain | |
paymentattemptscreditcard | integer | | | | plain | |
paymentacceptedoutagecredit | integer | | | | plain | |
totalmoneyin | numeric(12,2) | | | | main | |
updatewhen1 | timestamp without time zone | | | | plain | |
updatewhen2 | timestamp without time zone | | | | plain | |
Indexes:
\du Display user roles
- To view all users and their roles, use
\du
:
postgres=# \du
List of roles
Role name | Attributes | Member of
------------+------------------------------------------------------------+-----------
smanager | Superuser | {}
postgres | Superuser, Create role, Create DB, Replication, Bypass RLS | {}
tom | Superuser, Create role, Create DB | {}
- To view the role of a specific user, pass it after the
\du
command.
For example, to see the onlytom
role:
postgres=# \du tom
List of roles
Role name | Attributes | Member of
------------+------------------------------------------------------------+-----------
tom | Superuser, Create role, Create DB | {}
Creating a database
Before you add tables, you need to create a database to contain those tables.
That’s not done with psql
, but instead it’s done with createdb
(a separate external command; see the PostgreSQL createdb documentation) at the operating system command line:
# Replace markets with your database name
$ createdb markets
On success, there is no visual feedback. Thanks, PostgreSQL.
Adding tables and records
Creating a table (CREATE TABLE)
To add a table schema to the database:
postgres=# create table if not exists product (
id SERIAL,
name VARCHAR(100) NOT NULL,
sku CHAR(8)
);
And psql
responds with:
For more see CREATE TABLE
in the PostgreSQL official docs.
Adding a record (INSERT INTO)
- Here’s how to add a record, populating every field:
# The id field is an automatically assigned
# when you use DEFAULT. The serial primary key means
# that number will be increased by at least
# 1 and assigned to that same field when
# a new record is created.
# Using DEFAULT is a placeholder.
# In its place PostgreSQL automatically generates a unique integer for it.
postgres=# INSERT INTO product VALUES(DEFAULT, 'Apple, Fuji', '4131');
PostgreSQL responds with:
- Try it again and you get a simliar response.
postgres=# INSERT INTO product VALUES(DEFAULT, 'Banana', '4011');
INSERT 0 1
Adding (inserting) several records at once
- You can enter a list of records using this syntax:
postgres=# INSERT INTO product VALUES
(DEFAULT, 'Carrots', 4562),
(DEFAULT, 'Durian', 5228)
;
Adding only specific (columns) fields from a record
You can add records but specify only selected fields (also known as columns). MySQL will use common sense default values for the rest.
In this example, only the name
field will be populated. The sku
column is left blank, and the id
column is incremented and inserted.
Two records are added:
postgres=# INSERT INTO product (name) VALUES
('Endive'),
('Figs')
;
PostgreSQL responds with the number of records inserted:
INSERT 0 2
For more on INSERT, see INSERT
in the PostgreSQL official docs
Doing a simple query–get a list of records (SELECT)
Probably the most common thing you’ll do with a table is to obtain information about it
with the SELECT
statement. It’s a huge topic
- Let’s list all the records in the
product
table:
postgres=# SELECT * FROM product;
The response:
postgres=# select * from product;
id | name | sku
----+-------------+----------
1 | Apple, Fuji | 4131
2 | Banana | 4011
(2 rows)
Note
If your table has mixed case objects such as column names or indexes, you’ll need to enclose them in double quotes.
For example, If a column name were Product
instead of product
your query would need to look like this:
For more on SELECT, see the SELECT
in the PostgreSQL official docs.
Maintenance and operations issues
Timing
\t Timing SQL operations
Use \t
to show timing for all SQL operations performed.
Command | Effect |
---|---|
\timing off |
Disable timing of SQL operations |
\timing on |
Show timing after all SQL operations |
\timing |
Toggle (reverse) the setting |
Example of \t Timing command
tom=# insert into todo values ('Retry on Android before app submission,'8.x and earlier');
INSERT 0 1
tom=# \timing on
Timing is on.
tom=# insert into todo values ('Correct footer bug','Mobile version only');
INSERT 0 1
Time: 1.067 ms
tom=# insert into todo values ('Retry on Android before app submission', '8.x and earlier');
INSERT 0 1
Time: 23.312 ms
tom=# \timing
Timing is off.
Watch
The \watch
command repeats the previous command at the specified interval.
To use it, enter the SQL command you want repeated, then
use \watch
followed by the number of seconds you want for
the interval between repeats, for rexample, \watch 1
to repeat it every second.
Example of the \Watch command
Here’s an example of using \watch
to see if any records have been
inserted within the last 5 seconds.
tom=# select count(*);
count
--------
726
(726 rows)
tom=# \watch 5
Mon Nov 16 13:50:36 2020 (every 2s)
count
--------
726
(726 rows)
Mon Nov 16 13:50:38 2020 (every 2s)
count
--------
726
(726 rows)
Mon Nov 16 13:50:40 2020 (every 2s)
count
--------
726
(726 rows)
Locate the pg_hba.conf file
Postgres configuration is stored in a file named pg_hba.conf
somewhere in the file system, but
that location varies widely. The way to find it is to use show hba_file
like this:
See below for hot reloading this file while Postgres is running.
Reload the configuration file while Postgres is running
If you make changes to the pg_hba.conf
Postgres configuration sometimes you need to restart.
But you may just choose to reload the pg_hba.conf
configuration file like this:
Reference
- PostgreSQL offical docs: Server Administration
psql
, a.k.a the PostgreSQL interactive terminalcreatedb
in the PostgreSQL offical docsCREATE TABLE
in the PostgreSQL official docsINSERT
in the PostgreSQL official docs
Материал из Кафедра ИУ5 МГТУ им. Н.Э.Баумана, студенческое сообщество
В статье пойдёт речь о том, как добиться корректного вывода кириллицы в «консоли» Windows (cmd.exe
).
Описание проблемы
В дистрибутив PostgreSQL, помимо всего прочего, для работы с СУБД входит:
- приложение с графическим интерфейсом
pgAdmin
; - консольная утилита
psql
.
При работе с psql
в среде Windows пользователи всегда довольно часто сталкиваются с проблемой вывода кириллицы. Например, при отображении результатов запроса к таблице, в полях которых хранятся строковые данные на русском языке.
Ну и зачем тогда работать с psql
, кому нужно долбить клавиатурой в консольке, когда можно всё сделать красиво и быстро в pgAdmin
? Ну, не всегда pgAdmin
доступен, особенно если речь идёт об удалённой машине. Кроме того, выполнение SQL-запросов в текстовом режиме консоли — это +10 к хакирству.
Решение проблемы
Версии ПО:
- MS Windows 7 SP1 x64;
- PostgreSQL 8.4.12 x32.
На сервере имеется БД, созданная в кодировке UTF8.
Суть
Суть проблемы в том, что cmd.exe
работает (и так будет до скончания времён) в кодировке CP866
, а сама Windows — в WIN1251
, о чём psql
предупреждает при начале работы:
WARNING: Console code page (866) differs from Windows code page (1251) 8-bit characters might not work correctly. See psql reference page "Notes for Windows users" for details.
Значит, надо как-то добиться, чтобы кодировка была одна.
В разных источниках встречаются разные рецепты, включая правку реестра и подмену файлов в системных папках Windows. Ничего этого делать не нужно, достаточно всего трёх шагов:
- сменить шрифт у
cmd.exe
; - сменить текущую кодовую страницу
cmd.exe
; - сменить кодировку на стороне клиента в
psql
.
Конкретные действия
Супер быстро и просто
Запускаете cmd.exe
, оттуда psql
:
psql -d ВАШАБАЗА -U ВАШЛОГИН
Далее:
psql \! chcp 1251
Быстро и просто
Запускаете cmd.exe
, оттуда psql
:
psql -d ВАШАБАЗА -U ВАШЛОГИН
Вводите пароль (если установлен) и выполняете команду:
set client_encoding='WIN866';
И всё. Теперь результаты запроса, содержащие кириллицу, будут отображаться нормально. Но есть небольшой косяк:
Потому предлагаем ещё способ, который этого недостатка лишён.
Посложнее и подольше
Запустить cmd.exe
, нажать мышью в правом левом верхнем углу окна, там Свойства — Шрифт — выбрать Lucida Console. Нажать ОК.
Выполнить команду:
chcp 1251
В ответ выведет:
Текущая кодовая страница: 1251
Запустить psql
;
psql -d ВАШАБАЗА -U ВАШЛОГИН
Кстати, обратите внимание — теперь предупреждения о несовпадении кодировок нет.
Выполнить:
set client_encoding='win1251';
Он выведет:
SET
Всё, теперь кириллица будет нормально отображаться.
Проверяем:
By Gerard Hynes
Now is a great time to learn relational databases and SQL. From web development to data science, they are used everywhere.
In the Stack Overflow 2021 Survey, 4 out of the top 5 database technologies used by professional developers were relational database management systems.
PostgreSQL is an excellent choice as a first relational database management system to learn.
- It’s widely used in industry, including at Uber, Netflix, Instagram, Spotify, and Twitch.
- It’s open source, so you won’t be locked into a particular vendor.
- It’s more than 25 years old, and in that time it has earned a reputation for stability and reliability.
Whether you’re learning from the freeCodeCamp Relational Database Certification or trying out PostgreSQL on your own computer, you need a way to create and manage databases, insert data into them, and query data from them.
While there are several graphical applications for interacting with PostgreSQL, using psql and the command line is probably the most direct way to communicate with your database.
What is psql?
psql is a tool that lets you interact with PostgreSQL databases through a terminal interface. When you install PostgreSQL on a machine, psql is automatically included.
psql lets you write SQL queries, send them to PostgreSQL, and view the results. It also lets you use meta-commands (which start with a backslash) for administering the databases. You can even write scripts and automate tasks relating to your databases.
Now, running a database on your local computer and using the command line can seem intimidating at first. I’m here to tell you it’s really not so bad. This guide will teach you the basics of managing PostgreSQL databases from the command line, including how to create, manage, back up, and restore databases.
Prerequisite – Install PostgreSQL
If you haven’t already installed PostgreSQL on your computer, follow the instructions for your operating system on the official PostgreSQL documentation.
When you install PostgreSQL, you will be asked for a password. Keep this in a safe place as you’ll need it to connect to any databases you create.
How to Connect to a Database
You have two options when using psql to connect to a database: you can connect via the command line or by using the psql application. Both provide pretty much the same experience.
Option 1 – Connect to a database with the command line
Open a terminal. You can make sure psql is installed by typing psql --version
. You should see psql (PostgreSQL) version_number
, where version_number
is the version of PostgreSQL that’s installed on your machine. In my case, it’s 14.1.
Checking psql version via the command line
The pattern for connecting to a database is:
psql -d database_name -U username
The -d
flag is shorter alternative for --dbname
while -U
is an alternative for --username
.
When you installed PostgreSQL, a default database and user were created, both called postgres
. So enter psql -d postgres -U postgres
to connect to the postgres
database as the postgres
superuser.
psql -d postgres -U postgres
You will be prompted for a password. Enter the password you chose when you installed PostgreSQL on your computer. Your terminal prompt will change to show that you’re now connected to the postgres
database.
Connecting to a database from the command line with psql
If you want to directly connect to a database as yourself (rather than as the postgres
superuser), enter your system username as the username value.
Option 2 – Connect to a database with the psql application
Launch the psql application – it’ll be called «SQL Shell (psql)». You will be prompted for a server, a database, a port and a username. You can just press enter to select the default values, which are localhost
, postgres
, 5432
, and postgres
.
Next, you’ll be prompted for the password you chose when you installed PostgreSQL. Once you enter this, your terminal prompt will change to show that you’re connected to the postgres
database.
Connecting to a database with the psql application
Note: If you’re on Windows you might see a warning like “Console code page (850) differs from Windows code page (1252) 8-bit characters might not work correctly. See psql reference page ‘Notes for Windows users’ for details.” You don’t need to worry about this at this stage. If you want to read more about it, see the psql documentation.
How to Get Help in psql
To see a list of all psql meta-commands, and a brief summary of what they do, use the \?
command.
\?
psql’s help command
If you want help with a PostgreSQL command, use \h
or \help
and the command.
\h COMMAND
This will give you a description of the command, its syntax (with optional parts in square brackets), and a URL for the relevant part of the PostgreSQL documentation.
psql describing the DROP TABLE statement
How to Quit a Command in psql
If you’ve run a command that’s taking a long time or printing too much information to the console, you can quit it by typing q
.
q
How to Create a Database
Before you can manage any databases, you’ll need to create one.
Note: SQL commands should end with a semicolon, while meta-commands (which start with a backslash) don’t need to.
The SQL command to create a database is:
CREATE DATABASE database_name;
For this guide, we’re going to be working with book data, so let’s create a database called books_db
.
CREATE DATABASE books_db;
You can view a list of all available databases with the list command.
\l
Listing all databases
You should see books_db
, as well as postgres
, template0
, and template1
. (The CREATE DATABASE
command actually works by copying the standard database, called template1
. You can read more about this in the PostgreSQL documentation.)
Using \l+
will display additional information, such as the size of the databases and their tablespaces (the location in the filesystem where the files representing the database will be stored).
\l+
Listing all databases with additional information
How to Switch Databases
You’re currently still connected to the default postgres
database. To connect to a database or to switch between databases, use the \c
command.
\c database_name
So \c books_db
will connect you to the books_db
database. Note that your terminal prompt changes to reflect the database you’re currently connected to.
Switching databases
How to Delete a Database
If you want to delete a database, use the DROP DATABASE
command.
DROP DATABASE database_name;
You will only be allowed to delete a database if you are a superuser, such as postgres
, or if you are the database’s owner.
If you try to delete a database that doesn’t exist, you will get an error. Use IF EXISTS
to get a notice instead.
DROP DATABASE IF EXISTS database_name;
Deleting a database
You can’t delete a database that has active connections. So if you want to delete the database you are currently connected to, you’ll need to switch to another database.
How to Create Tables
Before we can manage tables, we need to create a few and populate them with some sample data.
The command to create a table is:
CREATE TABLE table_name();
This will create an empty table. You can also pass column values into the parentheses to create a table with columns. At the very least, a basic table should have a Primary Key (a unique identifier to tell each row apart) and a column with some data in it.
For our books_db
, we’ll create a table for authors and another for books. For authors, we’ll record their first name and last name. For books, we’ll record the title and the year they were published.
We’ll make sure that the authors’ first_name
and last_name
and the books’ title
aren’t null, since this is pretty vital information to know about them. To do this we include the NOT NULL
constraint.
CREATE TABLE authors(
author_id SERIAL PRIMARY KEY,
first_name VARCHAR(100) NOT NULL,
last_name VARCHAR(100) NOT NULL
);
CREATE TABLE books(
book_id SERIAL PRIMARY KEY,
title VARCHAR(100) NOT NULL,
published_year INT
);
You will see CREATE TABLE
printed to the terminal if the table was created successfully.
Now let’s connect the two tables by adding a Foreign Key to books. Foreign Keys are unique identifiers that reference the Primary Key of another table. Books can, of course, have multiple authors but we’re not going to get into the complexities of many to many relationships right now.
Add a Foreign Key to books
with the following command:
ALTER TABLE books ADD COLUMN author_id INT REFERENCES authors(author_id);
Next, let’s insert some sample data into the tables. We’ll start with authors
.
INSERT INTO authors (first_name, last_name)
VALUES (‘Tamsyn’, ‘Muir’), (‘Ann’, ‘Leckie’), (‘Zen’, ‘Cho’);
Select everything from authors
to make sure the insert command worked.
SELECT * FROM authors;
Querying all data from the authors table
Next, we’ll insert some books data into books
.
INSERT INTO books(title, published_year, author_id)
VALUES (‘Gideon the Ninth’, 2019, 1), (‘Ancillary Justice’, 2013, 2), (‘Black Water Sister’, 2021, 3);
If you run SELECT * FROM books;
you’ll see the book data.
Querying all data from the books table
How to List All Tables
You can use the \dt
command to list all the tables in a database.
\dt
For books_db
you will see books
and authors
. You’ll also see books_book_id_seq
and authors_author_id_seq
. These keep track of the sequence of integers used as ids by the tables because we used SERIAL
to generate their Primary Keys.
Listing all tables in a database
How to Describe a Table
To see more information about a particular table, you can use the describe table command: \d table_name
. This will list the columns, indexes, and any references to other tables.
\d table_name
Describing the authors table
Using \dt+ table_name
will provide more information, such as about storage and compression.
How to Rename a Table
If you ever need to change the name of a table, you can rename it with the ALTER TABLE
command.
ALTER TABLE table_name RENAME TO new_table_name;
How to Delete a Table
If you want to delete a table, you can use the DROP TABLE
command.
DROP TABLE table_name;
If you try to delete a table that doesn’t exist, you will get an error. You can avoid this by including the IF EXISTS
option in the statement. This way you’ll get a notice instead.
DROP TABLE IF EXISTS table_name;
How to Manage Longer Commands and Queries
If you’re writing longer SQL queries, the command line isn’t the most ergonomic way to do it. It’s probably better to write your SQL in a file and then have psql execute it.
If you are working with psql and think your next query will be long, you can open a text editor from psql and write it there. If you have an existing query, or maybe want to run several queries to load sample data, you can execute commands from a file that is already written.
Option 1 – Open a text editor from psql
If you enter the \e
command, psql will open a text editor. When you save and close the editor, psql will run the command you just wrote.
\e
Writing commands in a text editor
On Windows, the default text editor for psql is Notepad, while on MacOs and Linux it’s vi. You can change this to another editor by setting the EDITOR
value in your computer’s environment variables.
Option 2 – Execute commands and queries from a file
If you have particularly long commands or multiple commands that you want to run, it would be better to write the SQL in a file ahead of time and have psql execute that file once you’re ready.
The \i
command lets you read input from a file as if you had typed it into the terminal.
\i path_to_file/file_name.sql
Note: If you’re executing this command on Windows, you still need to use forward slashes in the file path.
If you don’t specify a path, psql will look for the file in the last directory that you were in before you connected to PostgreSQL.
Executing SQL commands from a file
How to Time Queries
If you want to see how long your queries are taking, you can turn on query execution timing.
\timing
This will display in milliseconds the time that the query took to complete.
If you run the \timing
command again, it will turn off query execution timing.
Using query execution timing
How to Import Data from a CSV File
If you have a CSV file with data and you want to load this into a PostgreSQL database, you can do this from the command line with psql.
First, create a CSV file called films.csv
with the following structure (It doesn’t matter if you use Excel, Google Sheets, Numbers, or any other program).
A spreadsheet with Pixar film data
Open psql and create a films_db
database, connect to it, and create a films
table.
CREATE DATABASE films_db;
\c films_db
CREATE TABLE films(
id SERIAL PRIMARY KEY,
title VARCHAR(100),
year INT,
running_time INT
);
You can then use the \copy
command to import the CSV file into films
. You need to provide an absolute path to where the CSV file is on your computer.
\copy films(title, year, running_time) FROM 'path_to_file' DELIMITER ‘,’ CSV HEADER;
The DELIMITER
option specifies the character that separates the columns in each row of the file being imported, CSV
specifies that it is a CSV file, and HEADER
specifies that the file contains a header line with the names of the columns.
Note: The column names of the films
table don’t need to match the column names of films.csv
but they do need to be in the same order.
Use SELECT * FROM films;
to see if the process was successful.
Importing data from a .csv file
How to Back Up a Database with pg_dump
If you need to backup a database, pg_dump
is a utility that lets you extract a database into a SQL script file or other type of archive file.
First, on the command line (not in psql), navigate to the PostgreSQL bin
folder.
cd "C:\Program Files\PostgreSQL\14\bin"
Then run the following command, using postgres
as the username, and filling in the database and output file that you want to use.
pg_dump -U username database_name > path_to_file/filename.sql
Use postgres
for the username and you will be prompted for the postgres
superuser’s password. pg_dump
will then create a .sql
file containing the SQL commands needed to recreate the database.
Backing up a database to a .sql file
If you don’t specify a path for the output file, pg_dump
will save the file in the last directory that you were in before you connected to PostgreSQL.
Contents of films.sql backup file
You can pass the -v
or --verbose
flag to pg_dump
to see what pg_dump
is doing at each step.
_Running pgdump in verbose mode
You can also backup a database to other file formats, such as .tar
(an archive format).
pg_dump -U username -F t database_name > path_to_file/filename.tar
Here the -F
flag tells pg_dump
that you’re going to specify an output format, while t
tells it it’s going to be in the .tar
format.
How to Restore a Database
You can restore a database from a backup file using either psql or the pg_restore
utility. Which one you choose depends on the type of file you are restoring the database from.
- If you backed up the database to a plaintext format, such as
.sql
, use psql. - If you backed up the database to an archive format, such as
.tar
, usepg_restore
.
Option 1 – Restore a database using psql
To restore a database from a .sql
file, on the command line (so not in psql), use psql -U username -d database_name -f filename.sql
.
You can use the films_db
database and films.sql
file you used earlier, or create a new backup file.
Create an empty database for the file to restore the data into. If you’re using films.sql
to restore films_db
, the easiest thing might be to delete films_db
and recreate it.
DROP DATABASE films_db;
CREATE DATABASE films_db;
In a separate terminal (not in psql), run the following command, passing in postgres
as the username, and the names of the database and backup file you are using.
psql -U username -d database_name -f path_to_file/filename.sql
The -d
flag points psql to a specific database, while the -f
flag tells psql to read from the specified file.
If you don’t specify a path for the backup file, psql will look for the file in the last directory that you were in before you connected to PostgreSQL.
You will be prompted for the postgres
superuser’s password and then will see a series of commands get printed to the command line while psql recreates the database.
Restoring a database using psql
This command ignores any errors that occur during the restore. If you want to stop restoring the database if an error occurs, pass in --set ON_ERROR_STOP=on
.
psql -U username -d database_name --set ON_ERROR_STOP=on -f filename.sql
Option 2 – Restore a database using pg_restore
To restore a database using pg_restore
, use pg_restore -U username -d database_name path_to_file/filename.tar
.
Create an empty database for the file to restore the data into. If you’re restoring films_db
from a films.tar
file, the easiest thing might be to delete films_db
and recreate it.
DROP DATABASE films_db;
CREATE DATABASE films_db;
On the command line (not in psql), run the following command, passing in postgres
as the username, and the names of the database and backup file you are using.
pg_restore -U username -d database_name path_to_file/filename.tar
_Restoring a database using pgrestore
You can also pass in the -v
or --verbose
flag to see what pg_restore
is doing at each step.
_Using pgrestore in verbose mode
How to Quit psql
If you’ve finished with psql and want to exit from it, enter quit
or \q
.
\q
This will close the psql application if you were using it, or return you to your regular command prompt if you were using psql from the command line.
Where to Take it from Here
There are lots more things you can do with psql, such as managing schemas, roles, and tablespaces. But this guide should be enough to get you started with managing PostgreSQL databases from the command line.
If you want to learn more about PostgreSQL and psql, you could try out freeCodeCamp’s Relational Database Certificate . The official PostgreSQL documentation is comprehensive, and PostgreSQL Tutorial offers several in-depth tutorials.
I hope you find this guide helpful as you continue to learn about PostgreSQL and relational databases.
Learn to code for free. freeCodeCamp’s open source curriculum has helped more than 40,000 people get jobs as developers. Get started