2016-06-02 08:05:46 -05:00
|
|
|
|
.. _backup_dialog:
|
|
|
|
|
|
2018-06-15 03:14:12 -05:00
|
|
|
|
**********************
|
|
|
|
|
`Backup Dialog`:index:
|
|
|
|
|
**********************
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2020-11-04 06:01:21 -06:00
|
|
|
|
*pgAdmin* uses the *pg_dump* utility to provide an easy way to create a backup
|
2019-03-08 09:29:05 -06:00
|
|
|
|
in a plain-text or archived format. You can then use a client application (like
|
|
|
|
|
*psql* or the *Query Tool*) to restore a plain-text backup file, or use the
|
|
|
|
|
Postgres *pg_restore* utility to restore an archived backup. The *pg_dump*
|
|
|
|
|
utility must have read access to all database objects that you want to back up.
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2019-03-08 09:29:05 -06:00
|
|
|
|
You can backup a single table, a schema, or a complete database. Select the name
|
|
|
|
|
of the backup source in the *pgAdmin* tree control, right click to open the
|
|
|
|
|
context menu, and select *Backup...* to open the *Backup* dialog. The name of
|
|
|
|
|
the object selected will appear in the dialog title bar.
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
|
|
|
|
.. image:: images/backup_general.png
|
2018-01-11 10:58:30 -06:00
|
|
|
|
:alt: Backup dialog general tab
|
2019-03-08 09:29:05 -06:00
|
|
|
|
:align: center
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
|
|
|
|
Use the fields in the *General* tab to specify parameters for the backup:
|
|
|
|
|
|
2019-03-08 09:29:05 -06:00
|
|
|
|
* Enter the name of the backup file in the *Filename* field. Optionally, select
|
|
|
|
|
the *Browser* icon (...) to the right to navigate into a directory and select
|
|
|
|
|
a file that will contain the archive.
|
|
|
|
|
|
|
|
|
|
* Use the drop-down listbox in the *Format* field to select the format that is
|
|
|
|
|
best suited for your application. Each format has advantages and
|
|
|
|
|
disadvantages:
|
|
|
|
|
|
|
|
|
|
* Select *Custom* to create a custom archive file that you can use with
|
|
|
|
|
*pg_restore* to create a copy of a database. Custom archive file formats
|
|
|
|
|
must be restored with *pg_restore*. This format offers the opportunity to
|
|
|
|
|
select which database objects to restore from the backup file. *Custom*
|
|
|
|
|
archive format is recommended for medium to large databases as it is
|
|
|
|
|
compressed by default.
|
|
|
|
|
|
|
|
|
|
* Select *Tar* to generate a tar archive file that you can restore with
|
|
|
|
|
*pg_restore*. The tar format does not support compression.
|
|
|
|
|
|
|
|
|
|
* Select *Plain* to create a plain-text script file. A plain-text script file
|
|
|
|
|
contains SQL statements and commands that you can execute at the *psql*
|
|
|
|
|
command line to recreate the database objects and load the table data. A
|
|
|
|
|
plain-text backup file can be edited in a text editor, if desired, before
|
|
|
|
|
using the *psql* program to restore database objects. *Plain* format is
|
|
|
|
|
normally recommended for smaller databases; script dumps are not
|
|
|
|
|
recommended for blobs. The SQL commands within the script will reconstruct
|
|
|
|
|
the database to the last saved state of the database. A plain-text script
|
|
|
|
|
can be used to reconstruct the database on another machine, or (with
|
|
|
|
|
modifications) on other architectures.
|
|
|
|
|
|
|
|
|
|
* Select *Directory* to generate a directory-format archive suitable for use
|
|
|
|
|
with *pg_restore*. This file format creates a directory with one file for
|
|
|
|
|
each table and blob being dumped, plus a *Table of Contents* file
|
|
|
|
|
describing the dumped objects in a machine-readable format that
|
|
|
|
|
*pg_restore* can read. This format is compressed by default.
|
|
|
|
|
|
|
|
|
|
* Use the *Compression Ratio* field to select a compression level for the
|
|
|
|
|
backup. Specify a value of zero to mean use no compression; specify a maximum
|
|
|
|
|
compression value of 9. Please note that tar archives do not support
|
|
|
|
|
compression.
|
|
|
|
|
* Use the *Encoding* drop-down listbox to select the character encoding method
|
|
|
|
|
that should be used for the archive.
|
|
|
|
|
* Use the *Number of Jobs* field (when applicable) to specify the number of
|
|
|
|
|
tables that will be dumped simultaneously in a parallel backup.
|
|
|
|
|
* Use the dropdown listbox next to *Rolename* to specify the role that owns the
|
|
|
|
|
backup.
|
|
|
|
|
|
2023-07-10 00:04:30 -05:00
|
|
|
|
Click the *Data Options* tab to continue. Use the fields in the *Data Options*
|
2022-01-07 00:05:40 -06:00
|
|
|
|
tab to provide options related to data or pgAdmin objects that correspond to *pg_dump*.
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
|
|
|
|
.. image:: images/backup_sections.png
|
2018-01-11 10:58:30 -06:00
|
|
|
|
:alt: Sections option on backup dialog
|
2019-03-08 09:29:05 -06:00
|
|
|
|
:align: center
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2019-03-08 09:29:05 -06:00
|
|
|
|
* Move switches in the **Sections** field box to select a portion of the object
|
|
|
|
|
that will be backed up.
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2022-01-07 00:05:40 -06:00
|
|
|
|
* Move the switch next to *Pre-data* towards right position to include all
|
2019-03-08 09:29:05 -06:00
|
|
|
|
data definition items not included in the data or post-data item lists.
|
2018-01-11 10:58:30 -06:00
|
|
|
|
|
2022-01-07 00:05:40 -06:00
|
|
|
|
* Move the switch next to *Data* towards right position to backup actual table
|
2019-03-08 09:29:05 -06:00
|
|
|
|
data, large-object contents, and sequence values.
|
2018-01-11 10:58:30 -06:00
|
|
|
|
|
2022-01-07 00:05:40 -06:00
|
|
|
|
* Move the switch next to *Post-data* towards right position to include
|
2019-03-08 09:29:05 -06:00
|
|
|
|
definitions of indexes, triggers, rules, and constraints other than
|
|
|
|
|
validated check constraints.
|
2018-01-11 10:58:30 -06:00
|
|
|
|
|
|
|
|
|
.. image:: images/backup_objects.png
|
|
|
|
|
:alt: Type of objects option on backup dialog
|
2019-03-08 09:29:05 -06:00
|
|
|
|
:align: center
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2019-03-08 09:29:05 -06:00
|
|
|
|
* Move switches in the **Type of objects** field box to specify details about
|
|
|
|
|
the type of objects that will be backed up.
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2022-01-07 00:05:40 -06:00
|
|
|
|
* Move the switch next to *Only data* towards right position to limit the back
|
2019-03-08 09:29:05 -06:00
|
|
|
|
up to data.
|
2018-01-11 10:58:30 -06:00
|
|
|
|
|
2023-07-10 00:04:30 -05:00
|
|
|
|
* Move the switch next to *Only schemas* to limit the back up to schema-level
|
2019-03-08 09:29:05 -06:00
|
|
|
|
database objects.
|
2018-01-11 10:58:30 -06:00
|
|
|
|
|
2022-01-07 00:05:40 -06:00
|
|
|
|
* Move the switch next to *Blobs* towards left position to exclude large
|
2019-03-08 09:29:05 -06:00
|
|
|
|
objects in the backup.
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
|
|
|
|
.. image:: images/backup_do_not_save.png
|
2018-01-11 10:58:30 -06:00
|
|
|
|
:alt: Do not save option on backup dialog
|
2019-03-08 09:29:05 -06:00
|
|
|
|
:align: center
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2019-03-08 09:29:05 -06:00
|
|
|
|
* Move switches in the **Do not save** field box to select the objects that will
|
|
|
|
|
not be included in the backup.
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2022-01-07 00:05:40 -06:00
|
|
|
|
* Move the switch next to *Owner* towards right position to exclude commands
|
2019-03-08 09:29:05 -06:00
|
|
|
|
that set object ownership.
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2023-07-10 00:04:30 -05:00
|
|
|
|
* Move the switch next to *Privileges* towards right position to exclude
|
2019-03-08 09:29:05 -06:00
|
|
|
|
commands that create access privileges.
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2023-07-10 00:04:30 -05:00
|
|
|
|
* Move the switch next to *Tablespaces* towards right position to exclude
|
2019-03-08 09:29:05 -06:00
|
|
|
|
tablespaces.
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2022-01-07 00:05:40 -06:00
|
|
|
|
* Move the switch next to *Unlogged table data* towards right position to
|
2019-03-08 09:29:05 -06:00
|
|
|
|
exclude the contents of unlogged tables.
|
2018-08-22 01:47:50 -05:00
|
|
|
|
|
2022-01-07 00:05:40 -06:00
|
|
|
|
* Move the switch next to *Comments* towards right position to exclude
|
2019-03-08 09:29:05 -06:00
|
|
|
|
commands that set the comments. **Note:** This option is visible only for
|
|
|
|
|
database server greater than or equal to 11.
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2023-07-10 00:04:30 -05:00
|
|
|
|
* Move the switch next to *Publications* towards right position to exclude
|
|
|
|
|
publications.
|
|
|
|
|
|
|
|
|
|
* Move the switch next to *Subscriptions* towards right position to exclude
|
|
|
|
|
subscriptions.
|
|
|
|
|
|
|
|
|
|
* Move the switch next to *Security labels* towards right position to exclude
|
|
|
|
|
Security labels.
|
|
|
|
|
|
|
|
|
|
* Move the switch next to *Toast compressions* towards right position to exclude
|
|
|
|
|
Toast compressions. **Note:** This option is visible only for
|
|
|
|
|
database server greater than or equal to 14.
|
|
|
|
|
|
|
|
|
|
* Move the switch next to *Table access methods* towards right position to exclude
|
|
|
|
|
Table access methods. **Note:** This option is visible only for
|
|
|
|
|
database server greater than or equal to 15.
|
2022-01-07 00:05:40 -06:00
|
|
|
|
|
2016-06-02 08:05:46 -05:00
|
|
|
|
.. image:: images/backup_queries.png
|
2018-01-11 10:58:30 -06:00
|
|
|
|
:alt: Queries option on backup dialog
|
2019-03-08 09:29:05 -06:00
|
|
|
|
:align: center
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2023-07-10 00:04:30 -05:00
|
|
|
|
Click the *Query Options* tab to continue. Use these additional fields to specify
|
|
|
|
|
the type of statements that should be included in the backup.
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2023-07-10 00:04:30 -05:00
|
|
|
|
* Move the switch next to *Use INSERT commands* towards right position to
|
2019-03-08 09:29:05 -06:00
|
|
|
|
dump the data in the form of INSERT statements rather than using a COPY
|
|
|
|
|
command. Please note: this may make restoration from backup slow.
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2023-07-10 00:04:30 -05:00
|
|
|
|
* Use the *Maximum rows per INSERT command* field to controls the maximum
|
|
|
|
|
number of rows per INSERT command. **Note:** This option is visible only for
|
|
|
|
|
database server greater than or equal to 12.
|
|
|
|
|
|
|
|
|
|
* Move the switch next to *On conflict do nothing to INSERT command* towards
|
|
|
|
|
right position to add ON CONFLICT DO NOTHING to INSERT command.
|
|
|
|
|
This option is not valid unless *Use INSERT commands*, *Use Column INSERTS*
|
|
|
|
|
or *Maximum rows per INSERT command* is also specified.
|
|
|
|
|
**Note:** This option is visible only for database server greater than or
|
|
|
|
|
equal to 12.
|
|
|
|
|
|
2022-01-07 00:05:40 -06:00
|
|
|
|
* Move the switch next to *Include CREATE DATABASE statement* towards right
|
2019-03-08 09:29:05 -06:00
|
|
|
|
position to include a command in the backup that creates a new database
|
|
|
|
|
when restoring the backup.
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2022-01-07 00:05:40 -06:00
|
|
|
|
* Move the switch next to *Include DROP DATABASE statement* towards right
|
2019-03-08 09:29:05 -06:00
|
|
|
|
position to include a command in the backup that will drop any existing
|
|
|
|
|
database object with the same name before recreating the object during a
|
|
|
|
|
backup.
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2023-07-10 00:04:30 -05:00
|
|
|
|
* Move the switch next to *Include IF EXISTS clause* towards right
|
|
|
|
|
position to add an IF EXISTS clause to drop databases and other objects.
|
|
|
|
|
This option is not valid unless *Include DROP DATABASE statement* is also set.
|
|
|
|
|
|
2023-07-13 02:31:48 -05:00
|
|
|
|
.. image:: images/backup_table.png
|
|
|
|
|
:alt: Backup dialog tables section
|
|
|
|
|
:align: center
|
2023-07-10 00:04:30 -05:00
|
|
|
|
|
|
|
|
|
Click the *Table Options* tab to continue. Use the fields in the *Table Options*
|
|
|
|
|
tab related to tables that should be included in the backup.
|
|
|
|
|
|
|
|
|
|
* Move the switch next to *Use Column INSERTS* towards right position to dump
|
|
|
|
|
the data in the form of INSERT statements and include explicit column
|
|
|
|
|
names. Please note: this may make restoration from backup slow.
|
|
|
|
|
|
|
|
|
|
* Move the switch next to *Load via partition root* towards right position,
|
2019-03-08 09:29:05 -06:00
|
|
|
|
so when dumping a COPY or INSERT statement for a partitioned table, target
|
|
|
|
|
the root of the partitioning hierarchy which contains it rather than the
|
|
|
|
|
partition itself. **Note:** This option is visible only for database server
|
|
|
|
|
greater than or equal to 11.
|
2018-08-22 01:47:50 -05:00
|
|
|
|
|
2023-07-10 00:04:30 -05:00
|
|
|
|
* Move the switch next to *Enable row security* towards right position to
|
|
|
|
|
set row_security to on instead, allowing the user to dump the parts of the
|
|
|
|
|
contents of the table that they have access to. This option is relevant
|
|
|
|
|
only when dumping the contents of a table which has row security.
|
|
|
|
|
|
2024-04-29 02:42:21 -05:00
|
|
|
|
* Use the *Include table(s) and Children* field to dump the tables and any partitions
|
|
|
|
|
or inheritance child tables of the tables matching the pattern.
|
|
|
|
|
**Note:** This option is visible only for database server greater than or
|
|
|
|
|
equal to 16.
|
|
|
|
|
|
|
|
|
|
* The Exclude patterns field is utilized to exclude patterns in the following manner:
|
2024-04-15 01:20:08 -05:00
|
|
|
|
|
2024-04-29 02:42:21 -05:00
|
|
|
|
* Use the *Table(s)* field to not dump the tables matching the
|
2024-04-15 01:20:08 -05:00
|
|
|
|
pattern. Multiple patterns can be given separated by space.
|
|
|
|
|
|
2024-04-29 02:42:21 -05:00
|
|
|
|
* Use the *Table(s) data* field to not dump data for any tables
|
|
|
|
|
matching the pattern. Multiple patterns can be given separated by
|
2024-04-15 01:20:08 -05:00
|
|
|
|
spaces.
|
|
|
|
|
|
2024-04-29 02:42:21 -05:00
|
|
|
|
* Use the *Table(s) and children* field to not dump the tables and any
|
|
|
|
|
partitions or inheritance child tables of the tables matching the pattern.
|
2024-04-15 01:20:08 -05:00
|
|
|
|
**Note:** This option is visible only for database server greater than or
|
|
|
|
|
equal to 16.
|
2023-07-10 00:04:30 -05:00
|
|
|
|
|
2024-04-29 02:42:21 -05:00
|
|
|
|
* Use the *Table(s) data and children* field to not dump data for the
|
|
|
|
|
tables and any partitions or inheritance child tables of the tables matching
|
|
|
|
|
the table pattern. **Note:** This option is visible only for database server
|
|
|
|
|
greater than or equal to 16.
|
|
|
|
|
|
2023-07-10 00:04:30 -05:00
|
|
|
|
Click the *Options* tab to continue. Use the fields in the *Options*
|
|
|
|
|
tab to provide other backup options.
|
|
|
|
|
|
2016-06-02 08:05:46 -05:00
|
|
|
|
.. image:: images/backup_disable.png
|
2018-01-11 10:58:30 -06:00
|
|
|
|
:alt: Disable option on backup dialog
|
2019-03-08 09:29:05 -06:00
|
|
|
|
:align: center
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2019-03-08 09:29:05 -06:00
|
|
|
|
* Move switches in the **Disable** field box to specify the type of statements
|
|
|
|
|
that should be excluded from the backup.
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2023-07-13 02:31:48 -05:00
|
|
|
|
* Move the switch next to *Triggers* (active when creating a data-only backup)
|
2022-01-07 00:05:40 -06:00
|
|
|
|
towards right position to include commands that will disable triggers on the
|
2019-03-08 09:29:05 -06:00
|
|
|
|
target table while the data is being loaded.
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2022-01-07 00:05:40 -06:00
|
|
|
|
* Move the switch next to *$ quoting* towards right position to enable dollar
|
2019-03-08 09:29:05 -06:00
|
|
|
|
quoting within function bodies; if disabled, the function body will be
|
|
|
|
|
quoted using SQL standard string syntax.
|
2018-01-11 10:58:30 -06:00
|
|
|
|
|
2016-06-02 08:05:46 -05:00
|
|
|
|
.. image:: images/backup_miscellaneous.png
|
2018-01-11 10:58:30 -06:00
|
|
|
|
:alt: Miscellaneous option on backup dialog
|
2019-03-08 09:29:05 -06:00
|
|
|
|
:align: center
|
|
|
|
|
|
|
|
|
|
* Move switches in the **Miscellaneous** field box to specify miscellaneous
|
|
|
|
|
backup options.
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2022-01-07 00:05:40 -06:00
|
|
|
|
* Move the switch next to *Verbose messages* towards left position to instruct
|
2019-03-08 09:29:05 -06:00
|
|
|
|
*pg_dump* to exclude verbose messages.
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2022-01-07 00:05:40 -06:00
|
|
|
|
* Move the switch next to *Force double quotes on identifiers* towards right
|
2019-03-08 09:29:05 -06:00
|
|
|
|
position to force the quoting of all identifiers.
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2022-01-07 00:05:40 -06:00
|
|
|
|
* Move the switch next to *Use SET SESSION AUTHORIZATION* towards right
|
2019-03-08 09:29:05 -06:00
|
|
|
|
position to include a statement that will use a SET SESSION AUTHORIZATION
|
|
|
|
|
command to determine object ownership (instead of an ALTER OWNER command).
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2023-07-13 02:31:48 -05:00
|
|
|
|
* Use the *Exclude schema* field to not dump schemas whose name matches
|
|
|
|
|
pattern.
|
|
|
|
|
|
2023-07-10 00:04:30 -05:00
|
|
|
|
* Use the *Extra float digits* field to use the specified value when dumping
|
|
|
|
|
floating-point data, instead of the maximum available precision.
|
|
|
|
|
|
|
|
|
|
* Use the *Lock wait timeout* field to do not wait forever to acquire shared
|
|
|
|
|
table locks at the beginning of the dump. Instead, fail if unable to lock a
|
|
|
|
|
table within the specified timeout.
|
|
|
|
|
|
2023-09-13 00:37:28 -05:00
|
|
|
|
Click the *Objects* tab to continue.
|
|
|
|
|
|
|
|
|
|
.. image:: images/backup_object_selection.png
|
|
|
|
|
:alt: Select objects in backup dialog
|
|
|
|
|
:align: center
|
|
|
|
|
|
|
|
|
|
* Select the objects from tree to take backup of selected objects only.
|
|
|
|
|
* If Schema is selected then it will take the backup of that selected schema only.
|
|
|
|
|
* If any Table, View, Materialized View, Sequences, or Foreign Table is selected then it will take the backup of those selected objects.
|
|
|
|
|
|
2019-03-08 09:29:05 -06:00
|
|
|
|
When you’ve specified the details that will be incorporated into the pg_dump
|
|
|
|
|
command:
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
2019-03-08 09:29:05 -06:00
|
|
|
|
* Click the *Backup* button to build and execute a command that builds a backup
|
|
|
|
|
based on your selections on the *Backup* dialog.
|
2016-06-02 08:05:46 -05:00
|
|
|
|
|
|
|
|
|
* Click the *Cancel* button to exit without saving work.
|
|
|
|
|
|
2022-08-11 00:19:45 -05:00
|
|
|
|
pgAdmin will run the backup process in background. You can view all the background
|
|
|
|
|
process with there running status and logs on the :ref:`Processes <processes>`
|
2023-07-10 00:04:30 -05:00
|
|
|
|
tab
|