diff --git a/server/src/main/java/org/apache/druid/client/CachingClusteredClient.java b/server/src/main/java/org/apache/druid/client/CachingClusteredClient.java index 2eea9aa594db..892e39e90079 100644 --- a/server/src/main/java/org/apache/druid/client/CachingClusteredClient.java +++ b/server/src/main/java/org/apache/druid/client/CachingClusteredClient.java @@ -436,20 +436,34 @@ private Set computeSegmentsToQuery( ); final Set segments = new LinkedHashSet<>(); - final Map>> dimensionRangeCache = new HashMap<>(); + final Map>> dimensionRangeCache; + final Set filterFieldsForPruning; + + final boolean trySecondaryPartititionPruning = + query.getFilter() != null && query.context().isSecondaryPartitionPruningEnabled(); + + if (trySecondaryPartititionPruning) { + dimensionRangeCache = new HashMap<>(); + filterFieldsForPruning = + DimFilterUtils.onlyBaseFields(query.getFilter().getRequiredColumns(), dataSourceAnalysis); + } else { + dimensionRangeCache = null; + filterFieldsForPruning = null; + } + // Filter unneeded chunks based on partition dimension for (TimelineObjectHolder holder : serversLookup) { final Set> filteredChunks; - if (query.getFilter() != null && query.context().isSecondaryPartitionPruningEnabled()) { + if (trySecondaryPartititionPruning) { filteredChunks = DimFilterUtils.filterShards( query.getFilter(), - DimFilterUtils.onlyBaseFields(query.getFilter().getRequiredColumns(), dataSourceAnalysis), + filterFieldsForPruning, holder.getObject(), partitionChunk -> partitionChunk.getObject().getSegment().getShardSpec(), dimensionRangeCache ); } else { - filteredChunks = Sets.newHashSet(holder.getObject()); + filteredChunks = Sets.newLinkedHashSet(holder.getObject()); } for (PartitionChunk chunk : filteredChunks) { ServerSelector server = chunk.getObject();