diff --git a/fe/fe-core/src/main/java/org/apache/doris/mtmv/MVCache.java b/fe/fe-core/src/main/java/org/apache/doris/mtmv/MVCache.java index 231ccbf0f67f53..b5cf92f87e4e73 100644 --- a/fe/fe-core/src/main/java/org/apache/doris/mtmv/MVCache.java +++ b/fe/fe-core/src/main/java/org/apache/doris/mtmv/MVCache.java @@ -42,7 +42,6 @@ public class MVCache { private final Plan logicalPlan; // this should be shuttle expression with lineage private final List mvOutputExpressions; - // the context when parse, analyze, optimize the mv logical plan public MVCache(MTMV materializedView, Plan logicalPlan, List mvOutputExpressions) { this.logicalPlan = logicalPlan; diff --git a/fe/fe-core/src/main/java/org/apache/doris/nereids/PlannerHook.java b/fe/fe-core/src/main/java/org/apache/doris/nereids/PlannerHook.java index 0fb95a28e5582c..18d71b539a94b3 100644 --- a/fe/fe-core/src/main/java/org/apache/doris/nereids/PlannerHook.java +++ b/fe/fe-core/src/main/java/org/apache/doris/nereids/PlannerHook.java @@ -23,9 +23,16 @@ * For example: after analyze plan when query or explain, we should generate materialization context. */ public interface PlannerHook { + + /** + * the hook before analyze + */ default void beforeAnalyze(NereidsPlanner planner) { } + /** + * the hook after analyze + */ default void afterAnalyze(NereidsPlanner planner) { } } diff --git a/fe/fe-core/src/main/java/org/apache/doris/nereids/rules/exploration/mv/AbstractMaterializedViewJoinRule.java b/fe/fe-core/src/main/java/org/apache/doris/nereids/rules/exploration/mv/AbstractMaterializedViewJoinRule.java index acc6c271ca29d2..384522c0f679c9 100644 --- a/fe/fe-core/src/main/java/org/apache/doris/nereids/rules/exploration/mv/AbstractMaterializedViewJoinRule.java +++ b/fe/fe-core/src/main/java/org/apache/doris/nereids/rules/exploration/mv/AbstractMaterializedViewJoinRule.java @@ -65,6 +65,8 @@ protected Plan rewriteQueryByView(MatchMode matchMode, || expressionsRewritten.stream().anyMatch(expr -> !(expr instanceof NamedExpression))) { return null; } + // record the group id in materializationContext, and when rewrite again in + // the same group, bail out quickly. if (queryStructInfo.getOriginalPlan().getGroupExpression().isPresent()) { materializationContext.addMatchedGroup( queryStructInfo.getOriginalPlan().getGroupExpression().get().getOwnerGroup().getGroupId()); @@ -88,10 +90,11 @@ protected boolean checkPattern(StructInfo structInfo) { SUPPORTED_JOIN_TYPE_SET)) { return false; } - for (Edge edge : hyperGraph.getEdges()) { - if (!edge.getJoin().accept(StructInfo.JOIN_PATTERN_CHECKER, SUPPORTED_JOIN_TYPE_SET)) { - return false; - } + } + for (Edge edge : hyperGraph.getEdges()) { + if (!edge.getJoin().accept(StructInfo.JOIN_PATTERN_CHECKER, + SUPPORTED_JOIN_TYPE_SET)) { + return false; } } return true; diff --git a/fe/fe-core/src/main/java/org/apache/doris/nereids/rules/exploration/mv/AbstractMaterializedViewRule.java b/fe/fe-core/src/main/java/org/apache/doris/nereids/rules/exploration/mv/AbstractMaterializedViewRule.java index 5eff40bd4bd896..09b2ea776150da 100644 --- a/fe/fe-core/src/main/java/org/apache/doris/nereids/rules/exploration/mv/AbstractMaterializedViewRule.java +++ b/fe/fe-core/src/main/java/org/apache/doris/nereids/rules/exploration/mv/AbstractMaterializedViewRule.java @@ -92,6 +92,7 @@ protected List rewrite(Plan queryPlan, CascadesContext cascadesContext) { } List queryToViewTableMappings = RelationMapping.generate(queryStructInfo.getRelations(), viewStructInfo.getRelations()); + // if any relation in query and view can not map, bail out. if (queryToViewTableMappings == null) { return rewriteResults; } @@ -161,7 +162,7 @@ protected Plan rewriteQueryByView(MatchMode matchMode, */ protected List rewriteExpression( List sourceExpressionsToWrite, - ExpressionMapping mvExpressionToMvScanExpressionMapping, + ExpressionMapping mvExprToMvScanExprMapping, SlotMapping sourceToTargetMapping) { // Firstly, rewrite the target plan output expression using query with inverse mapping // then try to use the mv expression to represent the query. if any of source expressions @@ -175,13 +176,14 @@ protected List rewriteExpression( // transform source to: // project(slot 2, 1) // target - // generate mvSql to mvScan mvExpressionToMvScanExpressionMapping, and change mv sql expression to query based - ExpressionMapping expressionMappingKeySourceBased = - mvExpressionToMvScanExpressionMapping.keyPermute(sourceToTargetMapping.inverse()); - List> flattenExpressionMap = - expressionMappingKeySourceBased.flattenMap(); + // generate mvSql to mvScan mvExprToMvScanExprMapping, and change mv sql expression to query based + ExpressionMapping mvExprToMvScanExprMappingKeySourceBased = + mvExprToMvScanExprMapping.keyPermute(sourceToTargetMapping.inverse()); + List> flattenExpressionMapping = + mvExprToMvScanExprMappingKeySourceBased.flattenMap(); // view to view scan expression is 1:1 so get first element - Map mvSqlToMvScanMappingQueryBased = flattenExpressionMap.get(0); + Map mvSqlToMvScanMappingQueryBased = + flattenExpressionMapping.get(0); List rewrittenExpressions = new ArrayList<>(); for (Expression expressionToRewrite : sourceExpressionsToWrite) { diff --git a/fe/fe-core/src/main/java/org/apache/doris/nereids/rules/exploration/mv/mapping/EquivalenceClassSetMapping.java b/fe/fe-core/src/main/java/org/apache/doris/nereids/rules/exploration/mv/mapping/EquivalenceClassSetMapping.java index f5153a20d9307f..d4ec09c24a4b8c 100644 --- a/fe/fe-core/src/main/java/org/apache/doris/nereids/rules/exploration/mv/mapping/EquivalenceClassSetMapping.java +++ b/fe/fe-core/src/main/java/org/apache/doris/nereids/rules/exploration/mv/mapping/EquivalenceClassSetMapping.java @@ -27,6 +27,8 @@ /** * EquivalenceClassSetMapping + * This will extract the equivalence class set in EquivalenceClass and mapping set in + * two different EquivalenceClass. */ public class EquivalenceClassSetMapping extends Mapping { @@ -42,7 +44,7 @@ public static EquivalenceClassSetMapping of(Map, Set expressionMapping;