8
0
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:
Dmitry Yemanov 2017-02-13 08:22:02 +03:00
parent 214921b3e6
commit 111296268b

View File

@ -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++)