Add TABLESPACE option to REINDEX
authorMichael Paquier <michael@paquier.xyz>
Thu, 4 Feb 2021 05:34:20 +0000 (14:34 +0900)
committerMichael Paquier <michael@paquier.xyz>
Thu, 4 Feb 2021 05:34:20 +0000 (14:34 +0900)
commitc5b286047cd698021e57a527215b48865fd4ad4e
treef6be35e4e5f3375949226731d3ce682398bd6c39
parent9624321ec502f4e4f4722290b358694049447f95
Add TABLESPACE option to REINDEX

This patch adds the possibility to move indexes to a new tablespace
while rebuilding them.  Both the concurrent and the non-concurrent cases
are supported, and the following set of restrictions apply:
- When using TABLESPACE with a REINDEX command that targets a
partitioned table or index, all the indexes of the leaf partitions are
moved to the new tablespace.  The tablespace references of the non-leaf,
partitioned tables in pg_class.reltablespace are not changed. This
requires an extra ALTER TABLE SET TABLESPACE.
- Any index on a toast table rebuilt as part of a parent table is kept
in its original tablespace.
- The operation is forbidden on system catalogs, including trying to
directly move a toast relation with REINDEX.  This results in an error
if doing REINDEX on a single object.  REINDEX SCHEMA, DATABASE and
SYSTEM skip system relations when TABLESPACE is used.

Author: Alexey Kondratov, Michael Paquier, Justin Pryzby
Reviewed-by: Álvaro Herrera, Michael Paquier
Discussion: https://postgr.es/m/8a8f5f73-00d3-55f8-7583-1375ca8f6a91@postgrespro.ru
doc/src/sgml/ref/reindex.sgml
src/backend/catalog/index.c
src/backend/commands/indexcmds.c
src/bin/psql/tab-complete.c
src/include/catalog/index.h
src/test/regress/input/tablespace.source
src/test/regress/output/tablespace.source