Allow multiple -n (schema) and -t (table) pg_dump options, and add -T
and -N options to exclude objects. Also support regular expressions for option object names. Greg Sabino Mullane
This commit is contained in:
parent
9a4eaa9440
commit
8977b68a42
@ -1,5 +1,5 @@
|
|||||||
<!--
|
<!--
|
||||||
$PostgreSQL: pgsql/doc/src/sgml/ref/pg_dump.sgml,v 1.86 2006/05/13 17:10:35 momjian Exp $
|
$PostgreSQL: pgsql/doc/src/sgml/ref/pg_dump.sgml,v 1.87 2006/08/01 18:05:04 momjian Exp $
|
||||||
PostgreSQL documentation
|
PostgreSQL documentation
|
||||||
-->
|
-->
|
||||||
|
|
||||||
@ -398,24 +398,107 @@ PostgreSQL documentation
|
|||||||
<listitem>
|
<listitem>
|
||||||
<para>
|
<para>
|
||||||
Dump data for <replaceable class="parameter">table</replaceable>
|
Dump data for <replaceable class="parameter">table</replaceable>
|
||||||
only. It is possible for there to be
|
only. It is possible for there to be multiple tables with the same
|
||||||
multiple tables with the same name in different schemas; if that
|
name in different schemas; if that is the case, all matching tables
|
||||||
is the case, all matching tables will be dumped. Specify both
|
will be dumped. Also, if any POSIX regular expression character appears
|
||||||
<option>--schema</> and <option>--table</> to select just one table.
|
in the table name (<literal>([{\.?+</>, the string will be interpreted
|
||||||
|
as a regular expression. Note that when in regular expression mode, the
|
||||||
|
string will not be anchored to the start/end unless <literal>^</> and
|
||||||
|
<literal>$</> are used at the beginning/end of the string.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
|
<para>
|
||||||
|
The options <option>-t</>, <option>-T</>, <option>-n</>, and <option>-N</>
|
||||||
|
can be used together to achieve a high degree of control over what is
|
||||||
|
dumped. Multiple arguments can be used, and are parsed in the order
|
||||||
|
given to build a list of valid tables and schemas. The schema options are
|
||||||
|
parsed first to create a list of schemas to dump, and then the table options
|
||||||
|
are parsed to only find tables in the matching schemas.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
<para>For example, to dump a single table named <literal>pg_class</>:
|
||||||
|
|
||||||
|
<screen>
|
||||||
|
<prompt>$</prompt> <userinput>pg_dump -t pg_class mydb > db.out</userinput>
|
||||||
|
</screen>
|
||||||
|
</para>
|
||||||
|
|
||||||
|
<para>To dump all tables starting with <literal>employee</> in the
|
||||||
|
<literal>detroit</> schema, except for the table named <literal>employee_log</literal>:
|
||||||
|
|
||||||
|
<screen>
|
||||||
|
<prompt>$</prompt> <userinput>pg_dump -n detroit -t ^employee -T employee_log mydb > db.out</userinput>
|
||||||
|
</screen>
|
||||||
|
</para>
|
||||||
|
|
||||||
|
<para>To dump all schemas starting with <literal>east</> or <literal>west</> and ending in
|
||||||
|
<literal>gsm</>, but not schemas that contain the letters <literal>test</>, except for
|
||||||
|
one named <literal>east_alpha_test_five</>:
|
||||||
|
|
||||||
|
<screen>
|
||||||
|
<prompt>$</prompt> <userinput>pg_dump -n "^(east|west).*gsm$" -N test -n east_alpha_test_five mydb > db.out</userinput>
|
||||||
|
</screen>
|
||||||
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
<para>To dump all tables except for those beginning with <literal>ts_</literal>:
|
||||||
|
|
||||||
|
<screen>
|
||||||
|
<prompt>$</prompt> <userinput>pg_dump -T "^ts_" mydb > db.out</userinput>
|
||||||
|
</screen>
|
||||||
|
</para>
|
||||||
|
|
||||||
|
|
||||||
<note>
|
<note>
|
||||||
<para>
|
<para>
|
||||||
In this mode, <application>pg_dump</application> makes no
|
In this mode, <application>pg_dump</application> makes no
|
||||||
attempt to dump any other database objects that the selected table
|
attempt to dump any other database objects that the selected tables
|
||||||
may depend upon. Therefore, there is no guarantee
|
may depend upon. Therefore, there is no guarantee
|
||||||
that the results of a single-table dump can be successfully
|
that the results of a specific-table dump can be successfully
|
||||||
restored by themselves into a clean database.
|
restored by themselves into a clean database.
|
||||||
</para>
|
</para>
|
||||||
</note>
|
</note>
|
||||||
</listitem>
|
</listitem>
|
||||||
</varlistentry>
|
</varlistentry>
|
||||||
|
|
||||||
|
<varlistentry>
|
||||||
|
<term><option>-T <replaceable class="parameter">table</replaceable></option></term>
|
||||||
|
<term><option>--exclude-table=<replaceable class="parameter">table</replaceable></option></term>
|
||||||
|
<listitem>
|
||||||
|
<para>
|
||||||
|
Do not dump any matching <replaceable class="parameter">tables</replaceable>.
|
||||||
|
More than one option can be used, and POSIX regular expressions are handled just
|
||||||
|
like <literal>-t</>.
|
||||||
|
</para>
|
||||||
|
</listitem>
|
||||||
|
</varlistentry>
|
||||||
|
|
||||||
|
<varlistentry>
|
||||||
|
<term><option>-n <replaceable class="parameter">schema</replaceable></option></term>
|
||||||
|
<term><option>--schema=<replaceable class="parameter">schema</replaceable></option></term>
|
||||||
|
<listitem>
|
||||||
|
<para>
|
||||||
|
Dump only the matching <replaceable class="parameter">schemas</replaceable>.
|
||||||
|
More than one option can be used, and POSIX regular expressions are handled just
|
||||||
|
like <literal>-t</>.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
</listitem>
|
||||||
|
</varlistentry>
|
||||||
|
|
||||||
|
<varlistentry>
|
||||||
|
<term><option>-N <replaceable class="parameter">schema</replaceable></option></term>
|
||||||
|
<term><option>--exclude-schema=<replaceable class="parameter">schema</replaceable></option></term>
|
||||||
|
<listitem>
|
||||||
|
<para>
|
||||||
|
Do not dump the matching <replaceable class="parameter">schemas</replaceable>.
|
||||||
|
More than one option can be used, and POSIX regular expressions are handled just
|
||||||
|
like <literal>-t</>.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
</listitem>
|
||||||
|
</varlistentry>
|
||||||
|
|
||||||
<varlistentry>
|
<varlistentry>
|
||||||
<term><option>-v</></term>
|
<term><option>-v</></term>
|
||||||
<term><option>--verbose</></term>
|
<term><option>--verbose</></term>
|
||||||
|
@ -11,7 +11,7 @@
|
|||||||
*
|
*
|
||||||
*
|
*
|
||||||
* IDENTIFICATION
|
* IDENTIFICATION
|
||||||
* $PostgreSQL: pgsql/src/bin/pg_dump/common.c,v 1.91 2006/07/14 14:52:26 momjian Exp $
|
* $PostgreSQL: pgsql/src/bin/pg_dump/common.c,v 1.92 2006/08/01 18:05:04 momjian Exp $
|
||||||
*
|
*
|
||||||
*-------------------------------------------------------------------------
|
*-------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -72,9 +72,7 @@ static int strInArray(const char *pattern, char **arr, int arr_size);
|
|||||||
* Collect information about all potentially dumpable objects
|
* Collect information about all potentially dumpable objects
|
||||||
*/
|
*/
|
||||||
TableInfo *
|
TableInfo *
|
||||||
getSchemaData(int *numTablesPtr,
|
getSchemaData(int *numTablesPtr)
|
||||||
const bool schemaOnly,
|
|
||||||
const bool dataOnly)
|
|
||||||
{
|
{
|
||||||
NamespaceInfo *nsinfo;
|
NamespaceInfo *nsinfo;
|
||||||
AggInfo *agginfo;
|
AggInfo *agginfo;
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
* by PostgreSQL
|
* by PostgreSQL
|
||||||
*
|
*
|
||||||
* IDENTIFICATION
|
* IDENTIFICATION
|
||||||
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_dump.c,v 1.442 2006/07/27 19:52:06 tgl Exp $
|
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_dump.c,v 1.443 2006/08/01 18:05:04 momjian Exp $
|
||||||
*
|
*
|
||||||
*-------------------------------------------------------------------------
|
*-------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -91,8 +91,19 @@ static const char *username_subquery;
|
|||||||
/* obsolete as of 7.3: */
|
/* obsolete as of 7.3: */
|
||||||
static Oid g_last_builtin_oid; /* value of the last builtin oid */
|
static Oid g_last_builtin_oid; /* value of the last builtin oid */
|
||||||
|
|
||||||
static char *selectTableName = NULL; /* name of a single table to dump */
|
/* select and exclude tables and schemas */
|
||||||
static char *selectSchemaName = NULL; /* name of a single schema to dump */
|
typedef struct objnameArg
|
||||||
|
{
|
||||||
|
struct objnameArg *next;
|
||||||
|
char *name; /* name of the relation */
|
||||||
|
bool is_include; /* include/exclude? */
|
||||||
|
} objnameArg;
|
||||||
|
|
||||||
|
objnameArg *schemaList = NULL; /* List of schemas to include/exclude */
|
||||||
|
objnameArg *tableList = NULL; /* List of tables to include/exclude */
|
||||||
|
|
||||||
|
char *matchingSchemas = NULL; /* Final list of schemas to dump by oid */
|
||||||
|
char *matchingTables = NULL; /* Final list of tables to dump by oid */
|
||||||
|
|
||||||
char g_opaque_type[10]; /* name for the opaque type */
|
char g_opaque_type[10]; /* name for the opaque type */
|
||||||
|
|
||||||
@ -180,6 +191,9 @@ static void check_sql_result(PGresult *res, PGconn *conn, const char *query,
|
|||||||
int
|
int
|
||||||
main(int argc, char **argv)
|
main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
|
PQExpBuffer query = createPQExpBuffer();
|
||||||
|
PGresult *res;
|
||||||
|
objnameArg *this_obj_name = NULL;
|
||||||
int c;
|
int c;
|
||||||
const char *filename = NULL;
|
const char *filename = NULL;
|
||||||
const char *format = "p";
|
const char *format = "p";
|
||||||
@ -195,6 +209,7 @@ main(int argc, char **argv)
|
|||||||
DumpableObject **dobjs;
|
DumpableObject **dobjs;
|
||||||
int numObjs;
|
int numObjs;
|
||||||
int i;
|
int i;
|
||||||
|
bool switch_include_exclude;
|
||||||
bool force_password = false;
|
bool force_password = false;
|
||||||
int compressLevel = -1;
|
int compressLevel = -1;
|
||||||
bool ignore_version = false;
|
bool ignore_version = false;
|
||||||
@ -226,9 +241,11 @@ main(int argc, char **argv)
|
|||||||
{"no-owner", no_argument, NULL, 'O'},
|
{"no-owner", no_argument, NULL, 'O'},
|
||||||
{"port", required_argument, NULL, 'p'},
|
{"port", required_argument, NULL, 'p'},
|
||||||
{"schema", required_argument, NULL, 'n'},
|
{"schema", required_argument, NULL, 'n'},
|
||||||
|
{"exclude-schema", required_argument, NULL, 'N'},
|
||||||
{"schema-only", no_argument, NULL, 's'},
|
{"schema-only", no_argument, NULL, 's'},
|
||||||
{"superuser", required_argument, NULL, 'S'},
|
{"superuser", required_argument, NULL, 'S'},
|
||||||
{"table", required_argument, NULL, 't'},
|
{"table", required_argument, NULL, 't'},
|
||||||
|
{"exclude-table", required_argument, NULL, 'T'},
|
||||||
{"password", no_argument, NULL, 'W'},
|
{"password", no_argument, NULL, 'W'},
|
||||||
{"username", required_argument, NULL, 'U'},
|
{"username", required_argument, NULL, 'U'},
|
||||||
{"verbose", no_argument, NULL, 'v'},
|
{"verbose", no_argument, NULL, 'v'},
|
||||||
@ -281,9 +298,11 @@ main(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
while ((c = getopt_long(argc, argv, "abcCdDE:f:F:h:in:oOp:RsS:t:uU:vWxX:Z:",
|
while ((c = getopt_long(argc, argv, "abcCdDE:f:F:h:in:N:oOp:RsS:t:T:uU:vWxX:Z:",
|
||||||
long_options, &optindex)) != -1)
|
long_options, &optindex)) != -1)
|
||||||
{
|
{
|
||||||
|
objnameArg *schemaList_tail = NULL, *tableList_tail = NULL;
|
||||||
|
|
||||||
switch (c)
|
switch (c)
|
||||||
{
|
{
|
||||||
case 'a': /* Dump data only */
|
case 'a': /* Dump data only */
|
||||||
@ -332,8 +351,42 @@ main(int argc, char **argv)
|
|||||||
ignore_version = true;
|
ignore_version = true;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'n': /* Dump data for this schema only */
|
case 'n': /* Include schemas */
|
||||||
selectSchemaName = strdup(optarg);
|
case 'N': /* Exclude schemas */
|
||||||
|
case 't': /* Include tables */
|
||||||
|
case 'T': /* Exclude tables */
|
||||||
|
|
||||||
|
if (strlen(optarg) < 1)
|
||||||
|
{
|
||||||
|
fprintf(stderr, _("%s: invalid -%c option\n"), progname, c);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
/* Create a struct for this name */
|
||||||
|
objnameArg *new_obj_name = (objnameArg *)
|
||||||
|
malloc(sizeof(objnameArg));
|
||||||
|
|
||||||
|
new_obj_name->next = NULL;
|
||||||
|
new_obj_name->name = strdup(optarg);
|
||||||
|
new_obj_name->is_include = islower(c) ? true : false;
|
||||||
|
|
||||||
|
/* add new entry to the proper list */
|
||||||
|
if (tolower(c) == 'n')
|
||||||
|
{
|
||||||
|
if (!schemaList_tail)
|
||||||
|
schemaList_tail = schemaList = new_obj_name;
|
||||||
|
else
|
||||||
|
schemaList_tail = schemaList_tail->next = new_obj_name;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (!tableList_tail)
|
||||||
|
tableList_tail = tableList = new_obj_name;
|
||||||
|
else
|
||||||
|
tableList_tail = tableList_tail->next = new_obj_name;
|
||||||
|
}
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'o': /* Dump oids */
|
case 'o': /* Dump oids */
|
||||||
@ -361,10 +414,6 @@ main(int argc, char **argv)
|
|||||||
outputSuperuser = strdup(optarg);
|
outputSuperuser = strdup(optarg);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 't': /* Dump data for this table only */
|
|
||||||
selectTableName = strdup(optarg);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 'u':
|
case 'u':
|
||||||
force_password = true;
|
force_password = true;
|
||||||
username = simple_prompt("User name: ", 100, true);
|
username = simple_prompt("User name: ", 100, true);
|
||||||
@ -449,7 +498,7 @@ main(int argc, char **argv)
|
|||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (selectTableName != NULL || selectSchemaName != NULL)
|
if (matchingTables != NULL || matchingSchemas != NULL)
|
||||||
outputBlobs = false;
|
outputBlobs = false;
|
||||||
|
|
||||||
if (dumpInserts == true && oids == true)
|
if (dumpInserts == true && oids == true)
|
||||||
@ -568,11 +617,157 @@ main(int argc, char **argv)
|
|||||||
write_msg(NULL, "last built-in OID is %u\n", g_last_builtin_oid);
|
write_msg(NULL, "last built-in OID is %u\n", g_last_builtin_oid);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (schemaList != NULL && g_fout->remoteVersion < 70300)
|
||||||
|
{
|
||||||
|
write_msg(NULL, "Postgres must be at least version 7.3 to use schema switches\n");
|
||||||
|
exit_nicely();
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Check schema selection flags */
|
||||||
|
resetPQExpBuffer(query);
|
||||||
|
switch_include_exclude = true;
|
||||||
|
for (this_obj_name = schemaList; this_obj_name; this_obj_name = this_obj_name->next)
|
||||||
|
{
|
||||||
|
if (switch_include_exclude)
|
||||||
|
{
|
||||||
|
/* Special case for when -N is the first argument */
|
||||||
|
if (this_obj_name == schemaList && !this_obj_name->is_include)
|
||||||
|
appendPQExpBuffer(query, "SELECT oid FROM pg_catalog.pg_namespace EXCEPT\n");
|
||||||
|
|
||||||
|
appendPQExpBuffer(query, "SELECT oid FROM pg_catalog.pg_namespace WHERE");
|
||||||
|
}
|
||||||
|
|
||||||
|
appendPQExpBuffer(query, "%s nspname %c ", switch_include_exclude ? "" : " OR",
|
||||||
|
/* any meta-characters? */
|
||||||
|
strpbrk(this_obj_name->name,"([{\\.?+") == NULL ? '=' : '~');
|
||||||
|
appendStringLiteralAH(query, this_obj_name->name, g_fout);
|
||||||
|
|
||||||
|
if (this_obj_name->next && this_obj_name->next->is_include == this_obj_name->is_include)
|
||||||
|
switch_include_exclude = false;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
switch_include_exclude = true;
|
||||||
|
|
||||||
|
/* Add the joiner if needed */
|
||||||
|
if (this_obj_name->next)
|
||||||
|
appendPQExpBuffer(query, "\n%s\n",
|
||||||
|
this_obj_name->next->is_include ? "UNION" : "EXCEPT");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Construct OID list of matching schemas */
|
||||||
|
if (schemaList)
|
||||||
|
{
|
||||||
|
int len;
|
||||||
|
|
||||||
|
res = PQexec(g_conn, query->data);
|
||||||
|
check_sql_result(res, g_conn, query->data, PGRES_TUPLES_OK);
|
||||||
|
if (PQntuples(res) == 0)
|
||||||
|
{
|
||||||
|
write_msg(NULL, "No matching schemas were found\n");
|
||||||
|
exit_nicely();
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0, len = strlen(" "); i < PQntuples(res); i++)
|
||||||
|
len += strlen(PQgetvalue(res, i, 0)) + 1;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Need to use comma separators so it can be used by IN. zero
|
||||||
|
* is a dummy placeholder. Format is " oid oid oid ".
|
||||||
|
*/
|
||||||
|
matchingSchemas = malloc(len + 1);
|
||||||
|
strcpy(matchingSchemas, " ");
|
||||||
|
for (i = 0; i < PQntuples(res); i++)
|
||||||
|
{
|
||||||
|
strcat(matchingSchemas, PQgetvalue(res, i, 0));
|
||||||
|
strcat(matchingSchemas, " ");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Check table selection flags */
|
||||||
|
resetPQExpBuffer(query);
|
||||||
|
switch_include_exclude = true;
|
||||||
|
for (this_obj_name = tableList; this_obj_name; this_obj_name = this_obj_name->next)
|
||||||
|
{
|
||||||
|
if (switch_include_exclude)
|
||||||
|
{
|
||||||
|
/* Special case for when -T is the first argument */
|
||||||
|
if (this_obj_name == tableList && !this_obj_name->is_include && !strlen(query->data))
|
||||||
|
appendPQExpBuffer(query, "SELECT oid FROM pg_catalog.pg_class WHERE relkind='r' EXCEPT\n");
|
||||||
|
|
||||||
|
appendPQExpBuffer(query, "SELECT oid FROM pg_catalog.pg_class WHERE relkind='r' AND (");
|
||||||
|
}
|
||||||
|
|
||||||
|
appendPQExpBuffer(query, "%srelname %c ", switch_include_exclude ? "" : " OR ",
|
||||||
|
/* any meta-characters? */
|
||||||
|
strpbrk(this_obj_name->name,"([{\\.?+") == NULL ? '=' : '~');
|
||||||
|
appendStringLiteralAH(query, this_obj_name->name, g_fout);
|
||||||
|
|
||||||
|
if (this_obj_name->next && this_obj_name->next->is_include == this_obj_name->is_include)
|
||||||
|
switch_include_exclude = false;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
switch_include_exclude = true;
|
||||||
|
appendPQExpBuffer(query, ")");
|
||||||
|
|
||||||
|
/* Add the joiner if needed */
|
||||||
|
if (this_obj_name->next)
|
||||||
|
appendPQExpBuffer(query, "\n%s\n", this_obj_name->next->is_include ?
|
||||||
|
"UNION" : "EXCEPT");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Construct OID list of matching tables */
|
||||||
|
if (tableList)
|
||||||
|
{
|
||||||
|
int len;
|
||||||
|
|
||||||
|
/* Restrict by schema? */
|
||||||
|
if (matchingSchemas != NULL)
|
||||||
|
{
|
||||||
|
char *matchingSchemas_commas = strdup(matchingSchemas), *p;
|
||||||
|
|
||||||
|
/* Construct "IN" SQL string by adding commas, " oid, oid, oid " */
|
||||||
|
for (p = matchingSchemas_commas; *p; p++)
|
||||||
|
{
|
||||||
|
/* No commas for first/last characters */
|
||||||
|
if (*p == ' ' && p != matchingSchemas_commas && *(p+1))
|
||||||
|
*p = ',';
|
||||||
|
}
|
||||||
|
|
||||||
|
appendPQExpBuffer(query,
|
||||||
|
"\nINTERSECT\nSELECT oid FROM pg_catalog.pg_class WHERE relkind='r' AND relnamespace IN (%s)\n",
|
||||||
|
matchingSchemas_commas);
|
||||||
|
}
|
||||||
|
|
||||||
|
res = PQexec(g_conn, query->data);
|
||||||
|
check_sql_result(res, g_conn, query->data, PGRES_TUPLES_OK);
|
||||||
|
if (PQntuples(res) == 0)
|
||||||
|
{
|
||||||
|
write_msg(NULL, "No matching tables were found\n");
|
||||||
|
exit_nicely();
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0, len = strlen(" "); i < PQntuples(res); i++)
|
||||||
|
len += strlen(PQgetvalue(res, i, 0)) + 1;
|
||||||
|
|
||||||
|
matchingTables = malloc(len + 1);
|
||||||
|
strcpy(matchingTables, " ");
|
||||||
|
for (i = 0; i < PQntuples(res); i++)
|
||||||
|
{
|
||||||
|
strcat(matchingTables, PQgetvalue(res, i, 0));
|
||||||
|
strcat(matchingTables, " ");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
destroyPQExpBuffer(query);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Now scan the database and create DumpableObject structs for all the
|
* Now scan the database and create DumpableObject structs for all the
|
||||||
* objects we intend to dump.
|
* objects we intend to dump.
|
||||||
*/
|
*/
|
||||||
tblinfo = getSchemaData(&numTables, schemaOnly, dataOnly);
|
tblinfo = getSchemaData(&numTables);
|
||||||
|
|
||||||
if (!schemaOnly)
|
if (!schemaOnly)
|
||||||
getTableData(tblinfo, numTables, oids);
|
getTableData(tblinfo, numTables, oids);
|
||||||
@ -628,7 +823,7 @@ main(int argc, char **argv)
|
|||||||
dumpStdStrings(g_fout);
|
dumpStdStrings(g_fout);
|
||||||
|
|
||||||
/* The database item is always next, unless we don't want it at all */
|
/* The database item is always next, unless we don't want it at all */
|
||||||
if (!dataOnly && selectTableName == NULL && selectSchemaName == NULL)
|
if (!dataOnly && matchingTables == NULL && matchingSchemas == NULL)
|
||||||
dumpDatabase(g_fout);
|
dumpDatabase(g_fout);
|
||||||
|
|
||||||
/* Now the rearrangeable objects. */
|
/* Now the rearrangeable objects. */
|
||||||
@ -687,28 +882,30 @@ help(const char *progname)
|
|||||||
printf(_(" --version output version information, then exit\n"));
|
printf(_(" --version output version information, then exit\n"));
|
||||||
|
|
||||||
printf(_("\nOptions controlling the output content:\n"));
|
printf(_("\nOptions controlling the output content:\n"));
|
||||||
printf(_(" -a, --data-only dump only the data, not the schema\n"));
|
printf(_(" -a, --data-only dump only the data, not the schema\n"));
|
||||||
printf(_(" -c, --clean clean (drop) schema prior to create\n"));
|
printf(_(" -c, --clean clean (drop) schema prior to create\n"));
|
||||||
printf(_(" -C, --create include commands to create database in dump\n"));
|
printf(_(" -C, --create include commands to create database in dump\n"));
|
||||||
printf(_(" -d, --inserts dump data as INSERT, rather than COPY, commands\n"));
|
printf(_(" -d, --inserts dump data as INSERT, rather than COPY, commands\n"));
|
||||||
printf(_(" -D, --column-inserts dump data as INSERT commands with column names\n"));
|
printf(_(" -D, --column-inserts dump data as INSERT commands with column names\n"));
|
||||||
printf(_(" -E, --encoding=ENCODING dump the data in encoding ENCODING\n"));
|
printf(_(" -E, --encoding=ENCODING dump the data in encoding ENCODING\n"));
|
||||||
printf(_(" -n, --schema=SCHEMA dump the named schema only\n"));
|
printf(_(" -n, --schema=SCHEMA dump the named schema only\n"));
|
||||||
printf(_(" -o, --oids include OIDs in dump\n"));
|
printf(_(" -N, --exclude-schema=SCHEMA do NOT dump the named schema\n"));
|
||||||
printf(_(" -O, --no-owner skip restoration of object ownership\n"
|
printf(_(" -o, --oids include OIDs in dump\n"));
|
||||||
" in plain text format\n"));
|
printf(_(" -O, --no-owner skip restoration of object ownership\n"
|
||||||
printf(_(" -s, --schema-only dump only the schema, no data\n"));
|
" in plain text format\n"));
|
||||||
printf(_(" -S, --superuser=NAME specify the superuser user name to use in\n"
|
printf(_(" -s, --schema-only dump only the schema, no data\n"));
|
||||||
" plain text format\n"));
|
printf(_(" -S, --superuser=NAME specify the superuser user name to use in\n"
|
||||||
printf(_(" -t, --table=TABLE dump the named table only\n"));
|
" plain text format\n"));
|
||||||
printf(_(" -x, --no-privileges do not dump privileges (grant/revoke)\n"));
|
printf(_(" -t, --table=TABLE dump the named table only\n"));
|
||||||
|
printf(_(" -T, --exclude-table=TABLE do NOT dump the named table\n"));
|
||||||
|
printf(_(" -x, --no-privileges do not dump privileges (grant/revoke)\n"));
|
||||||
printf(_(" -X disable-dollar-quoting, --disable-dollar-quoting\n"
|
printf(_(" -X disable-dollar-quoting, --disable-dollar-quoting\n"
|
||||||
" disable dollar quoting, use SQL standard quoting\n"));
|
" disable dollar quoting, use SQL standard quoting\n"));
|
||||||
printf(_(" -X disable-triggers, --disable-triggers\n"
|
printf(_(" -X disable-triggers, --disable-triggers\n"
|
||||||
" disable triggers during data-only restore\n"));
|
" disable triggers during data-only restore\n"));
|
||||||
printf(_(" -X use-set-session-authorization, --use-set-session-authorization\n"
|
printf(_(" -X use-set-session-authorization, --use-set-session-authorization\n"
|
||||||
" use SESSION AUTHORIZATION commands instead of\n"
|
" use SESSION AUTHORIZATION commands instead of\n"
|
||||||
" OWNER TO commands\n"));
|
" OWNER TO commands\n"));
|
||||||
|
|
||||||
printf(_("\nConnection options:\n"));
|
printf(_("\nConnection options:\n"));
|
||||||
printf(_(" -h, --host=HOSTNAME database server host or socket directory\n"));
|
printf(_(" -h, --host=HOSTNAME database server host or socket directory\n"));
|
||||||
@ -738,18 +935,20 @@ static void
|
|||||||
selectDumpableNamespace(NamespaceInfo *nsinfo)
|
selectDumpableNamespace(NamespaceInfo *nsinfo)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
* If a specific table is being dumped, do not dump any complete
|
* If specific tables are being dumped, do not dump any complete
|
||||||
* namespaces. If a specific namespace is being dumped, dump just that
|
* namespaces. If specific namespaces are being dumped, dump just
|
||||||
* namespace. Otherwise, dump all non-system namespaces.
|
* those namespaces. Otherwise, dump all non-system namespaces.
|
||||||
*/
|
*/
|
||||||
if (selectTableName != NULL)
|
if (matchingTables != NULL)
|
||||||
nsinfo->dobj.dump = false;
|
nsinfo->dobj.dump = false;
|
||||||
else if (selectSchemaName != NULL)
|
else if (matchingSchemas != NULL)
|
||||||
{
|
{
|
||||||
if (strcmp(nsinfo->dobj.name, selectSchemaName) == 0)
|
char *searchname = NULL;
|
||||||
|
searchname = malloc(20);
|
||||||
|
sprintf(searchname, " %d ", nsinfo->dobj.catId.oid);
|
||||||
|
if (strstr(matchingSchemas, searchname) != NULL)
|
||||||
nsinfo->dobj.dump = true;
|
nsinfo->dobj.dump = true;
|
||||||
else
|
free(searchname);
|
||||||
nsinfo->dobj.dump = false;
|
|
||||||
}
|
}
|
||||||
else if (strncmp(nsinfo->dobj.name, "pg_", 3) == 0 ||
|
else if (strncmp(nsinfo->dobj.name, "pg_", 3) == 0 ||
|
||||||
strcmp(nsinfo->dobj.name, "information_schema") == 0)
|
strcmp(nsinfo->dobj.name, "information_schema") == 0)
|
||||||
@ -771,16 +970,16 @@ selectDumpableTable(TableInfo *tbinfo)
|
|||||||
* dump.
|
* dump.
|
||||||
*/
|
*/
|
||||||
tbinfo->dobj.dump = false;
|
tbinfo->dobj.dump = false;
|
||||||
if (tbinfo->dobj.namespace->dobj.dump)
|
if (tbinfo->dobj.namespace->dobj.dump || matchingTables == NULL)
|
||||||
tbinfo->dobj.dump = true;
|
tbinfo->dobj.dump = true;
|
||||||
else if (selectTableName != NULL &&
|
else
|
||||||
strcmp(tbinfo->dobj.name, selectTableName) == 0)
|
|
||||||
{
|
{
|
||||||
/* If both -s and -t specified, must match both to dump */
|
char *searchname = NULL;
|
||||||
if (selectSchemaName == NULL)
|
searchname = malloc(20);
|
||||||
tbinfo->dobj.dump = true;
|
sprintf(searchname, " %d ", tbinfo->dobj.catId.oid);
|
||||||
else if (strcmp(tbinfo->dobj.namespace->dobj.name, selectSchemaName) == 0)
|
if (strstr(matchingTables, searchname) != NULL)
|
||||||
tbinfo->dobj.dump = true;
|
tbinfo->dobj.dump = true;
|
||||||
|
free(searchname);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1722,25 +1921,6 @@ getNamespaces(int *numNamespaces)
|
|||||||
nsinfo[i].dobj.name);
|
nsinfo[i].dobj.name);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* If the user attempted to dump a specific namespace, check to ensure
|
|
||||||
* that the specified namespace actually exists.
|
|
||||||
*/
|
|
||||||
if (selectSchemaName)
|
|
||||||
{
|
|
||||||
for (i = 0; i < ntups; i++)
|
|
||||||
if (strcmp(nsinfo[i].dobj.name, selectSchemaName) == 0)
|
|
||||||
break;
|
|
||||||
|
|
||||||
/* Didn't find a match */
|
|
||||||
if (i == ntups)
|
|
||||||
{
|
|
||||||
write_msg(NULL, "specified schema \"%s\" does not exist\n",
|
|
||||||
selectSchemaName);
|
|
||||||
exit_nicely();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
PQclear(res);
|
PQclear(res);
|
||||||
destroyPQExpBuffer(query);
|
destroyPQExpBuffer(query);
|
||||||
|
|
||||||
@ -2905,26 +3085,6 @@ getTables(int *numTables)
|
|||||||
tblinfo[i].dobj.name);
|
tblinfo[i].dobj.name);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* If the user is attempting to dump a specific table, check to ensure
|
|
||||||
* that the specified table actually exists. (This is a bit simplistic
|
|
||||||
* since we don't fully check the combination of -n and -t switches.)
|
|
||||||
*/
|
|
||||||
if (selectTableName)
|
|
||||||
{
|
|
||||||
for (i = 0; i < ntups; i++)
|
|
||||||
if (strcmp(tblinfo[i].dobj.name, selectTableName) == 0)
|
|
||||||
break;
|
|
||||||
|
|
||||||
/* Didn't find a match */
|
|
||||||
if (i == ntups)
|
|
||||||
{
|
|
||||||
write_msg(NULL, "specified table \"%s\" does not exist\n",
|
|
||||||
selectTableName);
|
|
||||||
exit_nicely();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
PQclear(res);
|
PQclear(res);
|
||||||
destroyPQExpBuffer(query);
|
destroyPQExpBuffer(query);
|
||||||
destroyPQExpBuffer(delqry);
|
destroyPQExpBuffer(delqry);
|
||||||
@ -5438,7 +5598,7 @@ dumpShellType(Archive *fout, ShellTypeInfo *stinfo)
|
|||||||
static bool
|
static bool
|
||||||
shouldDumpProcLangs(void)
|
shouldDumpProcLangs(void)
|
||||||
{
|
{
|
||||||
if (selectTableName != NULL || selectSchemaName != NULL)
|
if (matchingTables != NULL || matchingSchemas != NULL)
|
||||||
return false;
|
return false;
|
||||||
/* And they're schema not data */
|
/* And they're schema not data */
|
||||||
if (dataOnly)
|
if (dataOnly)
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
* Portions Copyright (c) 1996-2006, PostgreSQL Global Development Group
|
* Portions Copyright (c) 1996-2006, PostgreSQL Global Development Group
|
||||||
* Portions Copyright (c) 1994, Regents of the University of California
|
* Portions Copyright (c) 1994, Regents of the University of California
|
||||||
*
|
*
|
||||||
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_dump.h,v 1.127 2006/07/27 19:52:06 tgl Exp $
|
* $PostgreSQL: pgsql/src/bin/pg_dump/pg_dump.h,v 1.128 2006/08/01 18:05:04 momjian Exp $
|
||||||
*
|
*
|
||||||
*-------------------------------------------------------------------------
|
*-------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -340,9 +340,7 @@ extern char g_opaque_type[10]; /* name for the opaque type */
|
|||||||
* common utility functions
|
* common utility functions
|
||||||
*/
|
*/
|
||||||
|
|
||||||
extern TableInfo *getSchemaData(int *numTablesPtr,
|
extern TableInfo *getSchemaData(int *numTablesPtr);
|
||||||
const bool schemaOnly,
|
|
||||||
const bool dataOnly);
|
|
||||||
|
|
||||||
typedef enum _OidOptions
|
typedef enum _OidOptions
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user