Commit 16f38f72 authored by Noah Misch's avatar Noah Misch

Restore REINDEX constraint validation.

Refactoring as part of commit 8ceb2456
had the unintended effect of making REINDEX TABLE and REINDEX DATABASE
no longer validate constraints enforced by the indexes in question;
REINDEX INDEX still did so.  Indexes marked invalid remained so, and
constraint violations arising from data corruption went undetected.
Back-patch to 9.0, like the causative commit.
parent 000b65fd
...@@ -1768,7 +1768,9 @@ ReindexTable(RangeVar *relation) ...@@ -1768,7 +1768,9 @@ ReindexTable(RangeVar *relation)
heapOid = RangeVarGetRelidExtended(relation, ShareLock, false, false, heapOid = RangeVarGetRelidExtended(relation, ShareLock, false, false,
RangeVarCallbackOwnsTable, NULL); RangeVarCallbackOwnsTable, NULL);
if (!reindex_relation(heapOid, REINDEX_REL_PROCESS_TOAST)) if (!reindex_relation(heapOid,
REINDEX_REL_PROCESS_TOAST |
REINDEX_REL_CHECK_CONSTRAINTS))
ereport(NOTICE, ereport(NOTICE,
(errmsg("table \"%s\" has no indexes", (errmsg("table \"%s\" has no indexes",
relation->relname))); relation->relname)));
...@@ -1884,7 +1886,9 @@ ReindexDatabase(const char *databaseName, bool do_system, bool do_user) ...@@ -1884,7 +1886,9 @@ ReindexDatabase(const char *databaseName, bool do_system, bool do_user)
StartTransactionCommand(); StartTransactionCommand();
/* functions in indexes may want a snapshot set */ /* functions in indexes may want a snapshot set */
PushActiveSnapshot(GetTransactionSnapshot()); PushActiveSnapshot(GetTransactionSnapshot());
if (reindex_relation(relid, REINDEX_REL_PROCESS_TOAST)) if (reindex_relation(relid,
REINDEX_REL_PROCESS_TOAST |
REINDEX_REL_CHECK_CONSTRAINTS))
ereport(NOTICE, ereport(NOTICE,
(errmsg("table \"%s.%s\" was reindexed", (errmsg("table \"%s.%s\" was reindexed",
get_namespace_name(get_rel_namespace(relid)), get_namespace_name(get_rel_namespace(relid)),
......
...@@ -2298,9 +2298,13 @@ COMMIT; ...@@ -2298,9 +2298,13 @@ COMMIT;
BEGIN; BEGIN;
CREATE INDEX std_index on concur_heap(f2); CREATE INDEX std_index on concur_heap(f2);
COMMIT; COMMIT;
-- check to make sure that the failed indexes were cleaned up properly and the -- Failed builds are left invalid by VACUUM FULL, fixed by REINDEX
-- successful indexes are created properly. Notably that they do NOT have the VACUUM FULL concur_heap;
-- "invalid" flag set. REINDEX TABLE concur_heap;
ERROR: could not create unique index "concur_index3"
DETAIL: Key (f2)=(b) is duplicated.
DELETE FROM concur_heap WHERE f1 = 'b';
VACUUM FULL concur_heap;
\d concur_heap \d concur_heap
Table "public.concur_heap" Table "public.concur_heap"
Column | Type | Modifiers Column | Type | Modifiers
...@@ -2316,6 +2320,22 @@ Indexes: ...@@ -2316,6 +2320,22 @@ Indexes:
"concur_index5" btree (f2) WHERE f1 = 'x'::text "concur_index5" btree (f2) WHERE f1 = 'x'::text
"std_index" btree (f2) "std_index" btree (f2)
REINDEX TABLE concur_heap;
\d concur_heap
Table "public.concur_heap"
Column | Type | Modifiers
--------+------+-----------
f1 | text |
f2 | text |
Indexes:
"concur_index2" UNIQUE, btree (f1)
"concur_index3" UNIQUE, btree (f2)
"concur_heap_expr_idx" btree ((f2 || f1))
"concur_index1" btree (f2, f1)
"concur_index4" btree (f2) WHERE f1 = 'a'::text
"concur_index5" btree (f2) WHERE f1 = 'x'::text
"std_index" btree (f2)
-- --
-- Try some concurrent index drops -- Try some concurrent index drops
-- --
......
...@@ -721,10 +721,13 @@ BEGIN; ...@@ -721,10 +721,13 @@ BEGIN;
CREATE INDEX std_index on concur_heap(f2); CREATE INDEX std_index on concur_heap(f2);
COMMIT; COMMIT;
-- check to make sure that the failed indexes were cleaned up properly and the -- Failed builds are left invalid by VACUUM FULL, fixed by REINDEX
-- successful indexes are created properly. Notably that they do NOT have the VACUUM FULL concur_heap;
-- "invalid" flag set. REINDEX TABLE concur_heap;
DELETE FROM concur_heap WHERE f1 = 'b';
VACUUM FULL concur_heap;
\d concur_heap
REINDEX TABLE concur_heap;
\d concur_heap \d concur_heap
-- --
......
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