]> granicus.if.org Git - postgresql/commit
Fix REINDEX CONCURRENTLY of partitions
authorPeter Eisentraut <peter@eisentraut.org>
Fri, 12 Apr 2019 06:36:05 +0000 (08:36 +0200)
committerPeter Eisentraut <peter@eisentraut.org>
Fri, 12 Apr 2019 06:36:05 +0000 (08:36 +0200)
commitef6f30fe77af69a8c775cca82bf993b10c9889ee
tree318e3cc237fc57035c4d63ee766e110845b01d75
parentf7feb020c3d8d5aff24204af28359b99ee65bf8f
Fix REINDEX CONCURRENTLY of partitions

In case of a partition index, when swapping the old and new index, we
also need to attach the new index as a partition and detach the old
one.  Also, to handle partition indexes, we not only need to change
dependencies referencing the index, but also dependencies of the index
referencing something else.  The previous code did this only
specifically for a constraint, but we also need to do this for
partitioned indexes.  So instead write a generic function that does it
for all dependencies.

Author: Michael Paquier <michael@paquier.xyz>
Author: Peter Eisentraut <peter.eisentraut@2ndquadrant.com>
Discussion: https://www.postgresql.org/message-id/flat/DF4PR8401MB11964EDB77C860078C343BEBEE5A0%40DF4PR8401MB1196.NAMPRD84.PROD.OUTLOOK.COM#154df1fedb735190a773481765f7b874
src/backend/catalog/index.c
src/backend/catalog/pg_depend.c
src/include/catalog/dependency.h
src/test/regress/expected/create_index.out
src/test/regress/sql/create_index.sql