Commit 683abc73 authored by Tom Lane's avatar Tom Lane

Ignore invalid indexes in pg_dump.

Dumping invalid indexes can cause problems at restore time, for example
if the reason the index creation failed was because it tried to enforce
a uniqueness condition not satisfied by the table's data.  Also, if the
index creation is in fact still in progress, it seems reasonable to
consider it to be an uncommitted DDL change, which pg_dump wouldn't be
expected to dump anyway.

Back-patch to all active versions, and teach them to ignore invalid
indexes in servers back to 8.2, where the concept was introduced.

Michael Paquier
parent 625b237f
...@@ -4920,6 +4920,7 @@ getIndexes(Archive *fout, TableInfo tblinfo[], int numTables) ...@@ -4920,6 +4920,7 @@ getIndexes(Archive *fout, TableInfo tblinfo[], int numTables)
"i.indexrelid = c.conindid AND " "i.indexrelid = c.conindid AND "
"c.contype IN ('p','u','x')) " "c.contype IN ('p','u','x')) "
"WHERE i.indrelid = '%u'::pg_catalog.oid " "WHERE i.indrelid = '%u'::pg_catalog.oid "
"AND i.indisvalid "
"ORDER BY indexname", "ORDER BY indexname",
tbinfo->dobj.catId.oid); tbinfo->dobj.catId.oid);
} }
...@@ -4949,6 +4950,7 @@ getIndexes(Archive *fout, TableInfo tblinfo[], int numTables) ...@@ -4949,6 +4950,7 @@ getIndexes(Archive *fout, TableInfo tblinfo[], int numTables)
"ON (d.refclassid = c.tableoid " "ON (d.refclassid = c.tableoid "
"AND d.refobjid = c.oid) " "AND d.refobjid = c.oid) "
"WHERE i.indrelid = '%u'::pg_catalog.oid " "WHERE i.indrelid = '%u'::pg_catalog.oid "
"AND i.indisvalid "
"ORDER BY indexname", "ORDER BY indexname",
tbinfo->dobj.catId.oid); tbinfo->dobj.catId.oid);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment