diff options
author | Philip Warner <pjw@rhyme.com.au> | 2000-10-12 14:09:37 +0000 |
---|---|---|
committer | Philip Warner <pjw@rhyme.com.au> | 2000-10-12 14:09:37 +0000 |
commit | ceb6d01d76f3a630688d680cac8eb43a0acb00b1 (patch) | |
tree | 45b4168d659a50706aad092b0cdcdc54c1f953e1 /doc/src | |
parent | f41dcbe4d810f0906f43d1b345cf506d72c792ac (diff) | |
download | postgresql-ceb6d01d76f3a630688d680cac8eb43a0acb00b1.tar.gz postgresql-ceb6d01d76f3a630688d680cac8eb43a0acb00b1.zip |
First pass at docs for pg_restore
Diffstat (limited to 'doc/src')
-rw-r--r-- | doc/src/sgml/ref/pg_restore.sgml | 578 |
1 files changed, 578 insertions, 0 deletions
diff --git a/doc/src/sgml/ref/pg_restore.sgml b/doc/src/sgml/ref/pg_restore.sgml new file mode 100644 index 00000000000..b8e9e48fb22 --- /dev/null +++ b/doc/src/sgml/ref/pg_restore.sgml @@ -0,0 +1,578 @@ +<refentry id="APP-PGRESTORE"> + <refmeta> + <refentrytitle id="app-pgrestore-title"> + <application>pg_restore</application> + </refentrytitle> + <refmiscinfo>Application</refmiscinfo> + </refmeta> + <refnamediv> + <refname> + <application>pg_restore</application> + </refname> + <refpurpose> + Restore a <PRODUCTNAME>Postgres</PRODUCTNAME> database from an archive file created by
+<APPLICATION>pg_dump</APPLICATION>
+ </refpurpose> + </refnamediv> + <refsynopsisdiv> + <refsynopsisdivinfo> + <date>2000-10-11</date> + </refsynopsisdivinfo> + <synopsis>
+pg_restore [ <replaceable class="parameter">archive-file</replaceable> ]
+ [ -h <replaceable class="parameter">host</replaceable> ]
+ [ -p <replaceable class="parameter">port</replaceable> ]
+ [ -t <replaceable class="parameter">table</replaceable> ]
+ [ -a ] [ -c ] [-C] [-d <name>]
+ [-f <replaceable class="parameter">archive-file</replaceable>]
+ [-F <replaceable class="parameter">format</replaceable>]
+ [ -i <replaceable class="parameter">index</replaceable> ]
+ [ -l ] [ -N ] [ -o ] [ -O ]
+ [ -P <replaceable class="parameter">function-name</replaceable> ] [ -r ] [ -R ]
+ [ -s ] [ -S ] { -T <replaceable class="parameter">trigger</replaceable> ] [ -u ]
+ [-U <replaceable class="parameter">contents-file</replaceable> ] [ -v ] [ -x ]
+ </synopsis> + + <refsect2 id="R2-APP-PG-RESTORE-1"> + <refsect2info> + <date>2000-10-11</date> + </refsect2info> + <title> + Inputs + </title> + <para> + <application>pg_restore</application> accepts the following command + line arguments: + + <variablelist> + <varlistentry> + <term><replaceable class="parameter">archive-name</replaceable></term> + <listitem> + <para> + Specifies the location of the archive file to be restored.
+ If not specified, and no '-f' option is specified, then STDIN is used. + </para> + </listitem> + </varlistentry> + + <varlistentry> + <term>-a</term> + <listitem> + <para> + Restore only the data, no schema (definitions). + </para> + </listitem> + </varlistentry> + + <varlistentry>
+ <term>-c</term>
+ <listitem>
+ <para>
+ Clean (drop) schema prior to create.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>-C</term>
+ <listitem>
+ <para>
+ Include SQL to create the schema.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry> + <term>-d <replaceable class="parameter">dbname</replaceable></term> + <listitem> + <para> + Connect to database <replaceable class="parameter">dbname</replaceable> and restore
+ directly into the database. BLOBs can only be restored by using a direct database connection.
+ </para> + </listitem> + </varlistentry> + + <varlistentry>
+ <term>-f</term>
+ <listitem>
+ <para>
+ Specify output file for generated script. Default is STDOUT.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>-F <replaceable class="parameter">format</replaceable></term>
+ <listitem>
+ <para>
+ Specify format of the archive.
+ It is not necessary to specify the format, since <APPLICATION>pg_restore</APPLICATION> will
+ determine the format automatically. If specified, it can be one of the following:
+ </para>
+
+ <variablelist>
+
+ <varlistentry>
+ <term>t</term>
+ <listitem>
+ <para>
+ archive is a TAR archive. Using this archive format allows reordering and/or
+ exclusion of schema elements at the time the database is restored. It is also possible to limit which
+ data is reloaded at restore time.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>c</term>
+ <listitem>
+ <para>
+ archive is in the custom format from pg_dump. This is the most flexible format
+ in that it allows reordering of data load as well as schema elements.
+ This format is also compressed by default.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ </variablelist>
+
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>-i <replaceable class="parameter">index</replaceable></term>
+ <listitem>
+ <para>
+ Restore definition for named <replaceable class="parameter">index</replaceable> only.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>-l</term>
+ <listitem>
+ <para>
+ List the contents of the archive. The output of this command can be used with the '-U, --use-list' option
+ to restrict and reorder the items that are restored.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry> + <term>-N</term> + <listitem> + <para>
+ Restore items in the original dump order. By default pg_dump will dump items in an order convenient
+ to pg_dump, then save the archive in a modified OID order. This option overrides the OID ordering. + </para> + </listitem> + </varlistentry> + + <varlistentry> + <term>-o</term> + <listitem> + <para> + Restore items in the OID order. By default pg_dump will dump items in an order convenient
+ to pg_dump, then save the archive in a modified OID order. This option enforces strict OID ordering.
+ </para> + </listitem> + </varlistentry> + + <varlistentry> + <term>-O</term> + <listitem> + <para> + Prevent any attempt to restore original object ownership. Objects will be owned by the username used
+ to attach to the database.
+ </para> + </listitem> + </varlistentry> +
+ <varlistentry>
+ <term>-P <replaceable class="parameter">procedure-name</replaceable></term>
+ <listitem>
+ <para>
+ Specify a procedure or function to be restored.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>-r</term>
+ <listitem>
+ <para>
+ Restore items in modified OID order. By default pg_dump will dump items in an order convenient
+ to pg_dump, then save the archive in a modified OID order. Most objects
+ will be restored in OID order, but some things (eg. RULES & INDEXES) will be restored at the end of
+ the process irrespective of their OIDs. This option is the default.
+ </para>
+ </listitem>
+ </varlistentry>
+ + <varlistentry>
+ <term>-R</term>
+ <listitem>
+ <para>
+ Prohibit <APPLICATION>pg_restore</APPLICATION> from issuing any <PROGRAMLISTING>\connect</PROGRAMLISTING>
+ statements or reconnecting to the database if directly connected.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>-s</term>
+ <listitem>
+ <para>
+ Restore the schema (definitions), no data. Sequence values will be reset.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>-S <replaceable class="parameter">username</replaceable></term>
+ <listitem>
+ <para>
+ Specify the superuser username to use when disabling triggers and/or setting ownership of schema elements.
+ By default, <APPLICATION>pg_restore</APPLICATION> will use the current username if it is a superuser.
+ </para>
+ </listitem>
+ </varlistentry>
+ + <varlistentry>
+ <term>-t <replaceable class="parameter">table</replaceable></term>
+ <listitem>
+ <para>
+ Restore schema/data for <REPLACEABLE CLASS="PARAMETER">table</REPLACEABLE> only.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>-T <replaceable class="parameter">trigger</replaceable></term>
+ <listitem>
+ <para>
+ Restore definition of <REPLACEABLE CLASS="PARAMETER">trigger</REPLACEABLE> only.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry> + <term>-u</term> + <listitem> + <para> + Use password authentication. Prompts for username and password. + </para> + </listitem> + </varlistentry> + + <varlistentry>
+ <term>-U <replaceable class="parameter">list-file</replaceable></term>
+ <listitem>
+ <para>
+ Restore elements in <REPLACEABLE CLASS="PARAMETER">list-file</REPLACEABLE> only, and in the
+ order they appear in the file. Lines can be moved and may also be commented out by placing a ';' at the
+ start of the line.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry> + <term>-v</term> + <listitem> + <para> + Specifies verbose mode. + </para> + </listitem> + </varlistentry> + + <varlistentry> + <term>-x</term> + <listitem> + <para> + Prevent restoration of ACLs (grant/revoke commands). + </para> + </listitem> + </varlistentry> + + </variablelist> + </para> + <para> + <application>pg_restore</application> also accepts + the following command line arguments for connection parameters: + + <variablelist> + <varlistentry> + <term>-h <replaceable class="parameter">host</replaceable></term> + <listitem> + <para> + Specifies the hostname of the machine on which the + <application>postmaster</application> + is running. Defaults to using a local Unix domain socket + rather than an IP connection. + </para> + </listitem> + </varlistentry> + + <varlistentry> + <term>-p <replaceable class="parameter">port</replaceable></term> + <listitem> + <para> + Specifies the Internet TCP/IP port or local Unix domain socket file + extension on which the <application>postmaster</application> + is listening for connections. The port number defaults to 5432, + or the value of the <envar>PGPORT</envar> + environment variable (if set). + </para> + </listitem> + </varlistentry> + + </variablelist> + </para> + </refsect2> + + <refsect2 id="R2-APP-PG-RESTORE-2"> + <refsect2info> + <date>2000-10-11</date> + </refsect2info> + <title> + Outputs + </title> + <para> + <application>pg_restore</application> will create a script file, + write to <filename>stdout</filename>, or restore a database directly. + + <variablelist> + <varlistentry> + <term><computeroutput> +Connection to database 'template1' failed. +connectDB() failed: Is the postmaster running and accepting connections + at 'UNIX Socket' on port '<replaceable class="parameter">port</replaceable>'? + </computeroutput></term> + <listitem> + <para> + <application>pg_restore</application> could not attach to the + <application>postmaster</application> + process on the specified host and port. If you see this message, + ensure that the <application>postmaster</application> + is running on the proper host and that you have specified the proper + port. If your site uses an authentication system, ensure that you + have obtained the required authentication credentials. + </para> + </listitem> + </varlistentry> + + <varlistentry> + <term><computeroutput> +Connection to database '<replaceable class="parameter">dbname</replaceable>' failed. +FATAL 1: SetUserId: user '<replaceable class="parameter">username</replaceable>' is not in 'pg_shadow' + </computeroutput></term> + <listitem> + <para> + You do not have a valid entry in the relation <literal>pg_shadow</literal> + and and will not be allowed to access <productname>Postgres</productname>. + Contact your <productname>Postgres</productname> administrator. + </para> + </listitem> + </varlistentry> + + </variablelist> + </para> + + <note> + <para> + When a direct database connection is specified using the -d option, <application>pg_restore</application>
+ internally executes <command>SQL</command> statements. If you have problems running
+ <application>pg_restore</application>, + make sure you are able to select information from the database using, for + example, <application>psql</application>. + </para> + </note> + </refsect2> + </refsynopsisdiv> + + <refsect1 id="R1-APP-PG-RESTORE-1"> + <refsect1info> + <date>2000-10-11</date> + </refsect1info> + <title> + Description + </title> + <para> + <application>pg_restore</application> is a utility for restoring a
+ <productname>Postgres</productname> database dumped by <application>pg_dump</application>
+ from any one of the non-plain-text output formats.
+ </para> + + <para> + The archive files, new with this relase, contain enough information for
+ <application>pg_restore</application> to rebuild the database, but also allow
+ <application>pg_restore</application> to be selective about what is restored,
+ or even to reorder the items prior to being restored. The archive files should
+ also be portable across architectures. <application>pg_dump</application> will
+ produce the queries necessary to re-generate all user-defined types, functions,
+ tables, indices, aggregates, and operators. In addition, all the data is copied
+ out (in text format for scripts) so that it can be readily copied in again.
+ </para> +
+ <para>
+ <application>pg_restore</application> reads the archive file and outputs the appropriate
+ SQL in the required order based on the command parameters. Obviously, it can not restore
+ information that is not present in the dump file; so if the dump is made using the
+ 'dump data as inserts' option, <application>pg_restore</application> will not be able to
+ load the data using <command>COPY</command> statements.
+ </para>
+
+ <para>
+ The most flexible output file format is the new 'custom' format (-Fc). It allows for
+ selection and reordering of all archived items, and is compressed by default. The TAR
+ format (-Ft) is not compressed and it is not possible to reorder
+ data load, but it is otherwise quite flexible.
+ </para>
+
+ <para>
+ To reorder the items, it is first necessary to dump the contents of the archive:
+ <programlisting>
+ $ pg_restore acrhive.file --list > archive.lis
+ </programlisting>
+ This file consists of a header and one line for each item, eg.
+ <programlisting>
+;
+; Archive created at Fri Jul 28 22:28:36 2000
+; dbname: birds
+; TOC Entries: 74
+; Compression: 0
+; Dump Version: 1.4-0
+; Format: CUSTOM
+;
+;
+; Selected TOC Entries:
+;
+2; 145344 TABLE species postgres
+3; 145344 ACL species
+4; 145359 TABLE nt_header postgres
+5; 145359 ACL nt_header
+6; 145402 TABLE species_records postgres
+7; 145402 ACL species_records
+8; 145416 TABLE ss_old postgres
+9; 145416 ACL ss_old
+10; 145433 TABLE map_resolutions postgres
+11; 145433 ACL map_resolutions
+12; 145443 TABLE hs_old postgres
+13; 145443 ACL hs_old
+</programlisting>
+
+ Where semi-colons are comment delimiters, and the numbers at the start of lines refer to the
+ internal archive ID assigned to each item. Lines in the file can be commented out, deleted,
+ and/or reordered. For example,
+ <programlisting>
+10; 145433 TABLE map_resolutions postgres
+;2; 145344 TABLE species postgres
+;4; 145359 TABLE nt_header postgres
+6; 145402 TABLE species_records postgres
+;8; 145416 TABLE ss_old postgres
+ </programlisting>
+ </para>
+ <para>
+ Could be used as input to <application>pg_restore</application> and would only restore
+ items 10 and 6, in that order.
+ <programlisting>
+ $ pg_restore acrhive.file --use=archive.lis
+ </programlisting>
+ </para>
+
+ </refsect1> + + <refsect1 id="R1-APP-PG-RESTORE-2"> + <refsect1info> + <date>2000-10-11</date> + </refsect1info> + <title> + Notes + </title> + <para> + See the <application>pg_dump</application> section for details on limitation of
+ <application>pg_dump</application>.
+ </para>
+ <para> + The limitations of pg_restore are detailed below. + + <itemizedlist> + <listitem> + <para> + When restoring data to a table, <application>pg_restore</application> emits queries
+ to disable triggers on user tables before inserting the data then emits queries to
+ re-enable them after the data has been inserted. If the restore is stopped in the
+ middle, the system catalogs may be left in the wrong state. + </para> + </listitem> + + <listitem> + <para> + <application>pg_restore</application> will not restore BLOBs for a single table. If
+ an archive contains BLOBs, then all BLOBs will be restored. + </para> + </listitem> + + </itemizedlist> + </para> + </refsect1> + + <refsect1 id="R1-APP-PG-RESTORE-3"> + <refsect1info> + <date>2000-10-11</date> + </refsect1info> + <title> + Usage + </title> + <para> + To create a custom archive for a database of the same name as the user: + + <programlisting> +$ pg_dump -Fc > db.out + </programlisting> + </para> + + <para>
+ To reload this database:
+
+ <programlisting>
+$ pg_restore db.out | psql -e database
+ </programlisting>
+ </para>
+
+ <para>
+ To dump a database called mydb that contains BLOBs to a TAR file:
+
+ <programlisting>
+$ pg_dump -Ft mydb --blobs > db.tar
+ </programlisting>
+ </para>
+
+ <para>
+ To reload this database (with BLOBs) to an existing db called newdb:
+
+ <programlisting>
+$ pg_restore db.tar --db=newdb
+ </programlisting>
+ </para>
+
+
+ </refsect1> +</refentry> + +<!-- Keep this comment at the end of the file +Local variables: +mode: sgml +sgml-omittag:nil +sgml-shorttag:t +sgml-minimize-attributes:nil +sgml-always-quote-attributes:t +sgml-indent-step:1 +sgml-indent-data:t +sgml-parent-document:nil +sgml-default-dtd-file:"../reference.ced" +sgml-exposed-tags:nil +sgml-local-catalogs:"/usr/lib/sgml/catalog" +sgml-local-ecat-files:nil +End: +--> |