summaryrefslogtreecommitdiff
path: root/src/mongo/db/query/plan_cache_indexability.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/mongo/db/query/plan_cache_indexability.cpp')
-rw-r--r--src/mongo/db/query/plan_cache_indexability.cpp13
1 files changed, 3 insertions, 10 deletions
diff --git a/src/mongo/db/query/plan_cache_indexability.cpp b/src/mongo/db/query/plan_cache_indexability.cpp
index 522567ee71c..2de52b5dd91 100644
--- a/src/mongo/db/query/plan_cache_indexability.cpp
+++ b/src/mongo/db/query/plan_cache_indexability.cpp
@@ -79,7 +79,6 @@ IndexabilityDiscriminator getCollatedIndexDiscriminator(const CollatorInterface*
}
return true;
}
-
// The predicate never compares strings so it is not affected by collation.
return true;
};
@@ -104,14 +103,7 @@ void PlanCacheIndexabilityState::processSparseIndex(const std::string& indexName
void PlanCacheIndexabilityState::processPartialIndex(const std::string& indexName,
const MatchExpression* filterExpr) {
- invariant(filterExpr);
- for (size_t i = 0; i < filterExpr->numChildren(); ++i) {
- processPartialIndex(indexName, filterExpr->getChild(i));
- }
- if (filterExpr->getCategory() != MatchExpression::MatchCategory::kLogical) {
- _pathDiscriminatorsMap[filterExpr->path()][indexName].addDiscriminator(
- getPartialIndexDiscriminator(filterExpr));
- }
+ _globalDiscriminatorMap[indexName].addDiscriminator(getPartialIndexDiscriminator(filterExpr));
}
void PlanCacheIndexabilityState::processWildcardIndex(const CoreIndexInfo& cii) {
@@ -134,7 +126,7 @@ namespace {
const IndexToDiscriminatorMap emptyDiscriminators{};
} // namespace
-const IndexToDiscriminatorMap& PlanCacheIndexabilityState::getDiscriminators(
+const IndexToDiscriminatorMap& PlanCacheIndexabilityState::getPathDiscriminators(
StringData path) const {
PathDiscriminatorsMap::const_iterator it = _pathDiscriminatorsMap.find(path);
if (it == _pathDiscriminatorsMap.end()) {
@@ -166,6 +158,7 @@ IndexToDiscriminatorMap PlanCacheIndexabilityState::buildWildcardDiscriminators(
void PlanCacheIndexabilityState::updateDiscriminators(
const std::vector<CoreIndexInfo>& indexCores) {
_pathDiscriminatorsMap = PathDiscriminatorsMap();
+ _globalDiscriminatorMap = IndexToDiscriminatorMap();
_wildcardIndexDiscriminators.clear();
for (const auto& idx : indexCores) {