diff --git a/fe/fe-core/src/main/java/org/apache/doris/nereids/glue/translator/PhysicalPlanTranslator.java b/fe/fe-core/src/main/java/org/apache/doris/nereids/glue/translator/PhysicalPlanTranslator.java index ab72d99557..8117d9122d 100644 --- a/fe/fe-core/src/main/java/org/apache/doris/nereids/glue/translator/PhysicalPlanTranslator.java +++ b/fe/fe-core/src/main/java/org/apache/doris/nereids/glue/translator/PhysicalPlanTranslator.java @@ -1383,7 +1383,6 @@ public class PhysicalPlanTranslator extends DefaultPlanVisitor !(e.equals(BooleanLiteral.TRUE))) .flatMap(e -> e.getInputSlots().stream()) .map(SlotReference.class::cast) .forEach(s -> hashOutputSlotReferenceMap.put(s.getExprId(), s)); @@ -1525,11 +1524,10 @@ public class PhysicalPlanTranslator extends DefaultPlanVisitor sd.setIsNullable(true)); } + // Constant expr will cause be crash. + // But EliminateJoinCondition and Expression Rewrite already eliminate true literal. List otherJoinConjuncts = hashJoin.getOtherJoinConjuncts() .stream() - // TODO add constant expr will cause be crash, currently we only handle true literal. - // remove it after Nereids could ensure no constant expr in other join condition - .filter(e -> !(e.equals(BooleanLiteral.TRUE))) .map(e -> ExpressionTranslator.translate(e, context)) .collect(Collectors.toList());