pgsql: Fix marking of indisvalid for partitioned indexes at creation

Поиск
Список
Период
Сортировка
От Michael Paquier
Тема pgsql: Fix marking of indisvalid for partitioned indexes at creation
Дата
Msg-id E1qF6Ae-0018hA-V8@gemulon.postgresql.org
обсуждение исходный текст
Список pgsql-committers
Fix marking of indisvalid for partitioned indexes at creation

The logic that introduced partitioned indexes missed a few things when
invalidating a partitioned index when these are created, still the code
is written to handle recursions:
1) If created from scratch because a mapping index could not be found,
the new index created could be itself invalid, if for example it was a
partitioned index with one of its leaves invalid.
2) A CCI was missing when indisvalid is set for a parent index, leading
to inconsistent trees when recursing across more than one level for a
partitioned index creation if an invalidation of the parent was
required.

This could lead to the creation of a partition index tree where some of
the partitioned indexes are marked as invalid, but some of the parents
are marked valid, which is not something that should happen (as
validatePartitionedIndex() defines, indisvalid is switched to true for a
partitioned index iff all its partitions are themselves valid).

This patch makes sure that indisvalid is set to false on a partitioned
index if at least one of its partition is invalid.  The flag is set to
true if *all* its partitions are valid.

The regression test added in this commit abuses of a failed concurrent
index creation, marked as invalid, that maps with an index created on
its partitioned table afterwards.

Reported-by: Alexander Lakhin
Reviewed-by: Alexander Lakhin
Discussion: https://postgr.es/m/14987634-43c0-0cb3-e075-94d423607e08@gmail.com
Backpatch-through: 11

Branch
------
REL_12_STABLE

Details
-------
https://git.postgresql.org/pg/commitdiff/dbe0e5c56f313aec94cd8cf0c4f922867b2a95c5

Modified Files
--------------
src/backend/commands/indexcmds.c       | 29 ++++++++++++++++++++++------
src/test/regress/expected/indexing.out | 35 ++++++++++++++++++++++++++++++++++
src/test/regress/sql/indexing.sql      | 26 +++++++++++++++++++++++++
3 files changed, 84 insertions(+), 6 deletions(-)


В списке pgsql-committers по дате отправления:

Предыдущее
От: Michael Paquier
Дата:
Сообщение: pgsql: Add tab completion for CREATE SCHEMA in psql
Следующее
От: Michael Paquier
Дата:
Сообщение: pgsql: Introduce long options in pg_archivecleanup