Commit e24a815c authored by David Rowley's avatar David Rowley

Fix confusing NOTICE text in REINDEX CONCURRENTLY

When performing REINDEX TABLE CONCURRENTLY, if all of the table's indexes
could not be reindexed, a NOTICE message claimed that the table had no
indexes.  This was confusing, so let's change the NOTICE text to something
less confusing.

In passing, also mention in the comment before ReindexRelationConcurrently
that materialized views are supported too and also explain what the return
value of the function means.

Author: Ashwin Agrawal
Reviewed-by: Michael Paquier
Discussion: https://postgr.es/m/CALfoeithHvi13p_VyR8kt9o6Pa7Z=Smi6Nfc2anHnQx5Lj8bTQ@mail.gmail.com
parent 56b3b383
...@@ -2444,17 +2444,25 @@ ReindexTable(RangeVar *relation, int options, bool concurrent) ...@@ -2444,17 +2444,25 @@ ReindexTable(RangeVar *relation, int options, bool concurrent)
RangeVarCallbackOwnsTable, NULL); RangeVarCallbackOwnsTable, NULL);
if (concurrent) if (concurrent)
{
result = ReindexRelationConcurrently(heapOid, options); result = ReindexRelationConcurrently(heapOid, options);
if (!result)
ereport(NOTICE,
(errmsg("table \"%s\" has no indexes that can be reindexed concurrently",
relation->relname)));
}
else else
{
result = reindex_relation(heapOid, result = reindex_relation(heapOid,
REINDEX_REL_PROCESS_TOAST | REINDEX_REL_PROCESS_TOAST |
REINDEX_REL_CHECK_CONSTRAINTS, REINDEX_REL_CHECK_CONSTRAINTS,
options); options);
if (!result) if (!result)
ereport(NOTICE, ereport(NOTICE,
(errmsg("table \"%s\" has no indexes", (errmsg("table \"%s\" has no indexes to reindex",
relation->relname))); relation->relname)));
}
return heapOid; return heapOid;
} }
...@@ -2636,7 +2644,6 @@ ReindexMultipleTables(const char *objectName, ReindexObjectType objectKind, ...@@ -2636,7 +2644,6 @@ ReindexMultipleTables(const char *objectName, ReindexObjectType objectKind,
foreach(l, relids) foreach(l, relids)
{ {
Oid relid = lfirst_oid(l); Oid relid = lfirst_oid(l);
bool result;
StartTransactionCommand(); StartTransactionCommand();
/* functions in indexes may want a snapshot set */ /* functions in indexes may want a snapshot set */
...@@ -2644,11 +2651,13 @@ ReindexMultipleTables(const char *objectName, ReindexObjectType objectKind, ...@@ -2644,11 +2651,13 @@ ReindexMultipleTables(const char *objectName, ReindexObjectType objectKind,
if (concurrent) if (concurrent)
{ {
result = ReindexRelationConcurrently(relid, options); (void) ReindexRelationConcurrently(relid, options);
/* ReindexRelationConcurrently() does the verbose output */ /* ReindexRelationConcurrently() does the verbose output */
} }
else else
{ {
bool result;
result = reindex_relation(relid, result = reindex_relation(relid,
REINDEX_REL_PROCESS_TOAST | REINDEX_REL_PROCESS_TOAST |
REINDEX_REL_CHECK_CONSTRAINTS, REINDEX_REL_CHECK_CONSTRAINTS,
...@@ -2675,13 +2684,19 @@ ReindexMultipleTables(const char *objectName, ReindexObjectType objectKind, ...@@ -2675,13 +2684,19 @@ ReindexMultipleTables(const char *objectName, ReindexObjectType objectKind,
* ReindexRelationConcurrently - process REINDEX CONCURRENTLY for given * ReindexRelationConcurrently - process REINDEX CONCURRENTLY for given
* relation OID * relation OID
* *
* The relation can be either an index or a table. If it is a table, all its * 'relationOid' can either belong to an index, a table or a materialized
* valid indexes will be rebuilt, including its associated toast table * view. For tables and materialized views, all its indexes will be rebuilt,
* indexes. If it is an index, this index itself will be rebuilt. * excluding invalid indexes and any indexes used in exclusion constraints,
* but including its associated toast table indexes. For indexes, the index
* itself will be rebuilt. If 'relationOid' belongs to a partitioned table
* then we issue a warning to mention these are not yet supported.
* *
* The locks taken on parent tables and involved indexes are kept until the * The locks taken on parent tables and involved indexes are kept until the
* transaction is committed, at which point a session lock is taken on each * transaction is committed, at which point a session lock is taken on each
* relation. Both of these protect against concurrent schema changes. * relation. Both of these protect against concurrent schema changes.
*
* Returns true if any indexes have been rebuilt (including toast table's
* indexes, when relevant), otherwise returns false.
*/ */
static bool static bool
ReindexRelationConcurrently(Oid relationOid, int options) ReindexRelationConcurrently(Oid relationOid, int options)
......
...@@ -1944,9 +1944,9 @@ DROP TABLE reindex_verbose; ...@@ -1944,9 +1944,9 @@ DROP TABLE reindex_verbose;
CREATE TABLE concur_reindex_tab (c1 int); CREATE TABLE concur_reindex_tab (c1 int);
-- REINDEX -- REINDEX
REINDEX TABLE concur_reindex_tab; -- notice REINDEX TABLE concur_reindex_tab; -- notice
NOTICE: table "concur_reindex_tab" has no indexes NOTICE: table "concur_reindex_tab" has no indexes to reindex
REINDEX TABLE CONCURRENTLY concur_reindex_tab; -- notice REINDEX TABLE CONCURRENTLY concur_reindex_tab; -- notice
NOTICE: table "concur_reindex_tab" has no indexes NOTICE: table "concur_reindex_tab" has no indexes that can be reindexed concurrently
ALTER TABLE concur_reindex_tab ADD COLUMN c2 text; -- add toast index ALTER TABLE concur_reindex_tab ADD COLUMN c2 text; -- add toast index
-- Normal index with integer column -- Normal index with integer column
CREATE UNIQUE INDEX concur_reindex_ind1 ON concur_reindex_tab(c1); CREATE UNIQUE INDEX concur_reindex_ind1 ON concur_reindex_tab(c1);
...@@ -2043,10 +2043,10 @@ ERROR: REINDEX is not yet implemented for partitioned indexes ...@@ -2043,10 +2043,10 @@ ERROR: REINDEX is not yet implemented for partitioned indexes
-- REINDEX is a no-op for partitioned tables -- REINDEX is a no-op for partitioned tables
REINDEX TABLE concur_reindex_part_10; REINDEX TABLE concur_reindex_part_10;
WARNING: REINDEX of partitioned tables is not yet implemented, skipping "concur_reindex_part_10" WARNING: REINDEX of partitioned tables is not yet implemented, skipping "concur_reindex_part_10"
NOTICE: table "concur_reindex_part_10" has no indexes NOTICE: table "concur_reindex_part_10" has no indexes to reindex
REINDEX TABLE CONCURRENTLY concur_reindex_part_10; REINDEX TABLE CONCURRENTLY concur_reindex_part_10;
WARNING: REINDEX of partitioned tables is not yet implemented, skipping "concur_reindex_part_10" WARNING: REINDEX of partitioned tables is not yet implemented, skipping "concur_reindex_part_10"
NOTICE: table "concur_reindex_part_10" has no indexes NOTICE: table "concur_reindex_part_10" has no indexes that can be reindexed concurrently
SELECT relid, parentrelid, level FROM pg_partition_tree('concur_reindex_part_index') SELECT relid, parentrelid, level FROM pg_partition_tree('concur_reindex_part_index')
ORDER BY relid, level; ORDER BY relid, level;
relid | parentrelid | level relid | parentrelid | level
...@@ -2150,7 +2150,7 @@ DELETE FROM concur_reindex_tab4 WHERE c1 = 1; ...@@ -2150,7 +2150,7 @@ DELETE FROM concur_reindex_tab4 WHERE c1 = 1;
-- The invalid index is not processed when running REINDEX TABLE. -- The invalid index is not processed when running REINDEX TABLE.
REINDEX TABLE CONCURRENTLY concur_reindex_tab4; REINDEX TABLE CONCURRENTLY concur_reindex_tab4;
WARNING: cannot reindex invalid index "public.concur_reindex_ind5" concurrently, skipping WARNING: cannot reindex invalid index "public.concur_reindex_ind5" concurrently, skipping
NOTICE: table "concur_reindex_tab4" has no indexes NOTICE: table "concur_reindex_tab4" has no indexes that can be reindexed concurrently
\d concur_reindex_tab4 \d concur_reindex_tab4
Table "public.concur_reindex_tab4" Table "public.concur_reindex_tab4"
Column | Type | Collation | Nullable | Default Column | Type | Collation | Nullable | Default
......
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