| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
 | .\" This is -*-nroff-*-
.\" XXX standard disclaimer belongs here....
.\" $Header: /cvsroot/pgsql/src/man/Attic/pg_dump.1,v 1.6 1997/01/23 06:01:00 momjian Exp $
.TH PG_DUMP UNIX 1/20/96 PostgreSQL PostgreSQL
.SH NAME
pg_dump \(em dumps out a Postgres database into a script file
.SH SYNOPSIS
.BR pg_dump
[\c
.BR "-f"
filename
]
[\c
.BR "-H"
hostname
]
[\c
.BR "-p"
port]
[\c
.BR "-v"
]
[\c
.BR "-d"
]
[\c
.BR "-D"
]
[\c
.BR "-S"
help]
[\c
.BR "-a"
]
[\c
.BR "-t"
table]
[\c
.BR "-o"
]
dbname
.in -5n
.SH DESCRIPTION
.IR "pg_dump"
is a utility for dumping out a 
Postgres database into a script file containing query commands.  The script
files are in a ASCII format and can be used to reconstruct the database,
even on other machines and other architectures.  
.IR "pg_dump" 
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 ASCII format so
that it can be readily copied in again, as well, as imported into tools
for textual editing.
.PP
.IR "pg_dump" 
is useful for dumping out the contents of a database to move from one
postgreSQL installation to another.  After running 
.IR "pg_dump"
, one should examine the output script file for any warnings, especially
in light of the limitations listed below. 
.PP
pg_dump understands the following options:
.TP
.BR "-f" " filename"
Specifies the output file
.TP
.BR "-H" " hostname"
Specifies the server host name
.TP
.BR "-p" " port"
Specifies the server port number
.TP
.BR "-v" ""
Specifies verbose mode
.TP
.BR "-d" ""
Dump data as proper insert strings
.TP
.BR "-D" ""
Dump data as inserts with attribute names
.TP
.BR "-S" ""
Dump out only the schema, no data
.TP
.BR "-a" ""
Dump out only the data, no schema
.TP
.BR "-t" " table"
Dump for this table only
.TP
.BR "-o" ""
Dump object id's (oids)
.PP
If dbname is not supplied, then the DATABASE environment variable value is used.
.SH "CAVEATS AND LIMITATIONS"
.IR pg_dump 
has a few limitations.
The limitations mostly stem from
difficulty in extracting certain meta-information from the system
catalogs.   
.TP
.BR "rules and views"
pg_dump does not understand user-defined rules and views and
will fail to dump them properly.  (This is due to the fact that
rules are stored as plans in the catalogs and not textually)
.TP
.BR "partial indices"
pg_dump does not understand partial indices. (The reason is
the same as above.  Partial index predicates are stored as plans)
.TP
.BR "large objects"
pg_dump does not handle large objects.  Large objects are ignored and
must be dealt with manually. 
.SH EXAMPLES
.nf
To dump a database:
	pg_dump >db.out
To reload it:
	psql -e database <db.out
.SH "SEE ALSO"
copy(l)
 |