mirror of
https://github.com/postgres/postgres.git
synced 2025-07-05 07:21:24 +03:00
Fix interference between cavering indexes and partitioned tables
The bug is caused due to the original IndexStmt that DefineIndex receives being overwritten when processing the INCLUDE columns. Use separate list of index params to propagate to child tables. Add tests covering this case. Amit Langote and Alexander Korotkov.
This commit is contained in:
@ -342,6 +342,7 @@ DefineIndex(Oid relationId,
|
||||
Oid tablespaceId;
|
||||
Oid createdConstraintId = InvalidOid;
|
||||
List *indexColNames;
|
||||
List *allIndexParams;
|
||||
Relation rel;
|
||||
Relation indexRelation;
|
||||
HeapTuple tuple;
|
||||
@ -378,16 +379,16 @@ DefineIndex(Oid relationId,
|
||||
numberOfKeyAttributes = list_length(stmt->indexParams);
|
||||
|
||||
/*
|
||||
* We append any INCLUDE columns onto the indexParams list so that we have
|
||||
* one list with all columns. Later we can determine which of these are
|
||||
* key columns, and which are just part of the INCLUDE list by checking
|
||||
* the list position. A list item in a position less than
|
||||
* ii_NumIndexKeyAttrs is part of the key columns, and anything equal to
|
||||
* and over is part of the INCLUDE columns.
|
||||
* Calculate the new list of index columns including both key columns and
|
||||
* INCLUDE columns. Later we can determine which of these are key columns,
|
||||
* and which are just part of the INCLUDE list by checking the list
|
||||
* position. A list item in a position less than ii_NumIndexKeyAttrs is
|
||||
* part of the key columns, and anything equal to and over is part of the
|
||||
* INCLUDE columns.
|
||||
*/
|
||||
stmt->indexParams = list_concat(stmt->indexParams,
|
||||
stmt->indexIncludingParams);
|
||||
numberOfAttributes = list_length(stmt->indexParams);
|
||||
allIndexParams = list_concat(list_copy(stmt->indexParams),
|
||||
list_copy(stmt->indexIncludingParams));
|
||||
numberOfAttributes = list_length(allIndexParams);
|
||||
|
||||
if (numberOfAttributes <= 0)
|
||||
ereport(ERROR,
|
||||
@ -544,7 +545,7 @@ DefineIndex(Oid relationId,
|
||||
/*
|
||||
* Choose the index column names.
|
||||
*/
|
||||
indexColNames = ChooseIndexColumnNames(stmt->indexParams);
|
||||
indexColNames = ChooseIndexColumnNames(allIndexParams);
|
||||
|
||||
/*
|
||||
* Select name for index if caller didn't specify
|
||||
@ -658,7 +659,7 @@ DefineIndex(Oid relationId,
|
||||
coloptions = (int16 *) palloc(numberOfAttributes * sizeof(int16));
|
||||
ComputeIndexAttrs(indexInfo,
|
||||
typeObjectId, collationObjectId, classObjectId,
|
||||
coloptions, stmt->indexParams,
|
||||
coloptions, allIndexParams,
|
||||
stmt->excludeOpNames, relationId,
|
||||
accessMethodName, accessMethodId,
|
||||
amcanorder, stmt->isconstraint);
|
||||
@ -886,8 +887,8 @@ DefineIndex(Oid relationId,
|
||||
memcpy(part_oids, partdesc->oids, sizeof(Oid) * nparts);
|
||||
|
||||
parentDesc = CreateTupleDescCopy(RelationGetDescr(rel));
|
||||
opfamOids = palloc(sizeof(Oid) * numberOfAttributes);
|
||||
for (i = 0; i < numberOfAttributes; i++)
|
||||
opfamOids = palloc(sizeof(Oid) * numberOfKeyAttributes);
|
||||
for (i = 0; i < numberOfKeyAttributes; i++)
|
||||
opfamOids[i] = get_opclass_family(classObjectId[i]);
|
||||
|
||||
heap_close(rel, NoLock);
|
||||
|
Reference in New Issue
Block a user