diff --git a/fe/fe-core/src/main/java/org/apache/doris/nereids/rules/analysis/NormalizeAggregate.java b/fe/fe-core/src/main/java/org/apache/doris/nereids/rules/analysis/NormalizeAggregate.java index 325be7c5ab1236..ea3de56b034d99 100644 --- a/fe/fe-core/src/main/java/org/apache/doris/nereids/rules/analysis/NormalizeAggregate.java +++ b/fe/fe-core/src/main/java/org/apache/doris/nereids/rules/analysis/NormalizeAggregate.java @@ -231,17 +231,18 @@ private LogicalPlan normalizeAgg(LogicalAggregate aggregate, Optional normalizedAggOutput + ImmutableList.Builder normalizedAggOutputBuilder = ImmutableList.builderWithExpectedSize(groupingByExprs.size() + normalizedAggFuncs.size()); for (NamedExpression pushedGroupByExpr : pushedGroupByExprs) { - normalizedAggOutput.add(pushedGroupByExpr.toSlot()); + normalizedAggOutputBuilder.add(pushedGroupByExpr.toSlot()); } - normalizedAggOutput.addAll( + normalizedAggOutputBuilder.addAll( normalizedAggFuncsToSlotContext.pushDownToNamedExpression(normalizedAggFuncs) ); // create new agg node + ImmutableList normalizedAggOutput = normalizedAggOutputBuilder.build(); LogicalAggregate newAggregate = - aggregate.withNormalized(normalizedGroupExprs, normalizedAggOutput.build(), bottomPlan); + aggregate.withNormalized(normalizedGroupExprs, normalizedAggOutput, bottomPlan); // create upper projects by normalize all output exprs in old LogicalAggregate List upperProjects = normalizeOutput(aggregateOutput,