mirror of
https://github.com/FirebirdSQL/firebird.git
synced 2025-01-23 04:03:04 +01:00
Temporary fix for CORE-5481, a more complete solution is being developed.
This commit is contained in:
parent
214921b3e6
commit
111296268b
@ -1249,12 +1249,16 @@ InversionCandidate* OptimizerRetrieval::makeInversion(InversionCandidateList* in
|
||||
inversion[i]->used = false;
|
||||
const IndexScratch* const indexScratch = inversion[i]->scratch;
|
||||
|
||||
if (indexScratch && (indexScratch->idx->idx_runtime_flags & idx_plan_dont_use))
|
||||
if (indexScratch &&
|
||||
(indexScratch == navigationCandidate ||
|
||||
(indexScratch->idx->idx_runtime_flags & idx_plan_dont_use)))
|
||||
{
|
||||
inversion[i]->used = true;
|
||||
}
|
||||
}
|
||||
|
||||
// The matches returned in this inversion are always sorted.
|
||||
SortedArray<BoolExprNode*> matches;
|
||||
SortedArray<BoolExprNode*> matches, navigationMatches;
|
||||
|
||||
if (navigationCandidate)
|
||||
{
|
||||
@ -1269,11 +1273,13 @@ InversionCandidate* OptimizerRetrieval::makeInversion(InversionCandidateList* in
|
||||
|
||||
for (FB_SIZE_T j = 0; j < segment->matches.getCount(); j++)
|
||||
{
|
||||
if (!matches.exist(segment->matches[j]))
|
||||
matches.add(segment->matches[j]);
|
||||
if (!navigationMatches.exist(segment->matches[j]))
|
||||
navigationMatches.add(segment->matches[j]);
|
||||
}
|
||||
}
|
||||
|
||||
matches.join(navigationMatches);
|
||||
|
||||
// If the navigational candidate includes any matching segments,
|
||||
// reset the selectivity/cost prerequisites to account these matches
|
||||
if (matchedSegments)
|
||||
@ -1338,12 +1344,14 @@ InversionCandidate* OptimizerRetrieval::makeInversion(InversionCandidateList* in
|
||||
}
|
||||
|
||||
// Look if a match is already used by previous matches.
|
||||
bool anyMatchAlreadyUsed = false;
|
||||
bool anyMatchAlreadyUsed = false, matchUsedByNavigation = false;
|
||||
for (FB_SIZE_T k = 0; k < currentInv->matches.getCount(); k++)
|
||||
{
|
||||
if (matches.exist(currentInv->matches[k]))
|
||||
{
|
||||
anyMatchAlreadyUsed = true;
|
||||
if (navigationMatches.exist(currentInv->matches[k]))
|
||||
matchUsedByNavigation = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
@ -1351,6 +1359,8 @@ InversionCandidate* OptimizerRetrieval::makeInversion(InversionCandidateList* in
|
||||
if (anyMatchAlreadyUsed && !customPlan)
|
||||
{
|
||||
currentInv->used = true;
|
||||
if (matchUsedByNavigation)
|
||||
continue;
|
||||
// If a match on this index was already used by another
|
||||
// index, add also the other matches from this index.
|
||||
for (FB_SIZE_T j = 0; j < currentInv->matches.getCount(); j++)
|
||||
|
Loading…
Reference in New Issue
Block a user