org.apache.calcite.rel.metadata.DefaultRelMetadataProvider Java Examples
The following examples show how to use
org.apache.calcite.rel.metadata.DefaultRelMetadataProvider.
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example #1
Source File: RelOptMaterialization.java From Bats with Apache License 2.0 | 6 votes |
/** * Converts a relational expression to a form where * {@link org.apache.calcite.rel.logical.LogicalJoin}s are * as close to leaves as possible. */ public static RelNode toLeafJoinForm(RelNode rel) { final Program program = Programs.hep( ImmutableList.of( JoinProjectTransposeRule.RIGHT_PROJECT, JoinProjectTransposeRule.LEFT_PROJECT, FilterJoinRule.FilterIntoJoinRule.FILTER_ON_JOIN, ProjectRemoveRule.INSTANCE, ProjectMergeRule.INSTANCE), false, DefaultRelMetadataProvider.INSTANCE); if (CalciteSystemProperty.DEBUG.value()) { System.out.println( RelOptUtil.dumpPlan("before", rel, SqlExplainFormat.TEXT, SqlExplainLevel.DIGEST_ATTRIBUTES)); } final RelNode rel2 = program.run(null, rel, null, ImmutableList.of(), ImmutableList.of()); if (CalciteSystemProperty.DEBUG.value()) { System.out.println( RelOptUtil.dumpPlan("after", rel2, SqlExplainFormat.TEXT, SqlExplainLevel.DIGEST_ATTRIBUTES)); } return rel2; }
Example #2
Source File: RelOptMaterialization.java From calcite with Apache License 2.0 | 6 votes |
/** * Converts a relational expression to a form where * {@link org.apache.calcite.rel.logical.LogicalJoin}s are * as close to leaves as possible. */ public static RelNode toLeafJoinForm(RelNode rel) { final Program program = Programs.hep( ImmutableList.of( JoinProjectTransposeRule.RIGHT_PROJECT, JoinProjectTransposeRule.LEFT_PROJECT, FilterJoinRule.FilterIntoJoinRule.FILTER_ON_JOIN, ProjectRemoveRule.INSTANCE, ProjectMergeRule.INSTANCE), false, DefaultRelMetadataProvider.INSTANCE); if (CalciteSystemProperty.DEBUG.value()) { System.out.println( RelOptUtil.dumpPlan("before", rel, SqlExplainFormat.TEXT, SqlExplainLevel.DIGEST_ATTRIBUTES)); } final RelNode rel2 = program.run(null, rel, null, ImmutableList.of(), ImmutableList.of()); if (CalciteSystemProperty.DEBUG.value()) { System.out.println( RelOptUtil.dumpPlan("after", rel2, SqlExplainFormat.TEXT, SqlExplainLevel.DIGEST_ATTRIBUTES)); } return rel2; }
Example #3
Source File: Programs.java From Bats with Apache License 2.0 | 5 votes |
/** Creates a program that invokes heuristic join-order optimization * (via {@link org.apache.calcite.rel.rules.JoinToMultiJoinRule}, * {@link org.apache.calcite.rel.rules.MultiJoin} and * {@link org.apache.calcite.rel.rules.LoptOptimizeJoinRule}) * if there are 6 or more joins (7 or more relations). */ public static Program heuristicJoinOrder( final Iterable<? extends RelOptRule> rules, final boolean bushy, final int minJoinCount) { return (planner, rel, requiredOutputTraits, materializations, lattices) -> { final int joinCount = RelOptUtil.countJoins(rel); final Program program; if (joinCount < minJoinCount) { program = ofRules(rules); } else { // Create a program that gathers together joins as a MultiJoin. final HepProgram hep = new HepProgramBuilder() .addRuleInstance(FilterJoinRule.FILTER_ON_JOIN) .addMatchOrder(HepMatchOrder.BOTTOM_UP) .addRuleInstance(JoinToMultiJoinRule.INSTANCE) .build(); final Program program1 = of(hep, false, DefaultRelMetadataProvider.INSTANCE); // Create a program that contains a rule to expand a MultiJoin // into heuristically ordered joins. // We use the rule set passed in, but remove JoinCommuteRule and // JoinPushThroughJoinRule, because they cause exhaustive search. final List<RelOptRule> list = Lists.newArrayList(rules); list.removeAll( ImmutableList.of(JoinCommuteRule.INSTANCE, JoinAssociateRule.INSTANCE, JoinPushThroughJoinRule.LEFT, JoinPushThroughJoinRule.RIGHT)); list.add(bushy ? MultiJoinOptimizeBushyRule.INSTANCE : LoptOptimizeJoinRule.INSTANCE); final Program program2 = ofRules(list); program = sequence(program1, program2); } return program.run( planner, rel, requiredOutputTraits, materializations, lattices); }; }
Example #4
Source File: Programs.java From calcite with Apache License 2.0 | 5 votes |
/** Creates a program that invokes heuristic join-order optimization * (via {@link org.apache.calcite.rel.rules.JoinToMultiJoinRule}, * {@link org.apache.calcite.rel.rules.MultiJoin} and * {@link org.apache.calcite.rel.rules.LoptOptimizeJoinRule}) * if there are 6 or more joins (7 or more relations). */ public static Program heuristicJoinOrder( final Iterable<? extends RelOptRule> rules, final boolean bushy, final int minJoinCount) { return (planner, rel, requiredOutputTraits, materializations, lattices) -> { final int joinCount = RelOptUtil.countJoins(rel); final Program program; if (joinCount < minJoinCount) { program = ofRules(rules); } else { // Create a program that gathers together joins as a MultiJoin. final HepProgram hep = new HepProgramBuilder() .addRuleInstance(FilterJoinRule.FILTER_ON_JOIN) .addMatchOrder(HepMatchOrder.BOTTOM_UP) .addRuleInstance(JoinToMultiJoinRule.INSTANCE) .build(); final Program program1 = of(hep, false, DefaultRelMetadataProvider.INSTANCE); // Create a program that contains a rule to expand a MultiJoin // into heuristically ordered joins. // We use the rule set passed in, but remove JoinCommuteRule and // JoinPushThroughJoinRule, because they cause exhaustive search. final List<RelOptRule> list = Lists.newArrayList(rules); list.removeAll( ImmutableList.of(JoinCommuteRule.INSTANCE, JoinAssociateRule.INSTANCE, JoinPushThroughJoinRule.LEFT, JoinPushThroughJoinRule.RIGHT)); list.add(bushy ? MultiJoinOptimizeBushyRule.INSTANCE : LoptOptimizeJoinRule.INSTANCE); final Program program2 = ofRules(list); program = sequence(program1, program2); } return program.run( planner, rel, requiredOutputTraits, materializations, lattices); }; }
Example #5
Source File: Programs.java From Bats with Apache License 2.0 | 4 votes |
/** Returns the standard program used by Prepare. */ public static Program standard() { return standard(DefaultRelMetadataProvider.INSTANCE); }
Example #6
Source File: Programs.java From calcite with Apache License 2.0 | 4 votes |
/** Returns the standard program used by Prepare. */ public static Program standard() { return standard(DefaultRelMetadataProvider.INSTANCE); }
Example #7
Source File: RelMetadataTest.java From calcite with Apache License 2.0 | 4 votes |
private static RelNode convertSql(Tester tester, String sql) { final RelRoot root = tester.convertSqlToRel(sql); root.rel.getCluster().setMetadataProvider(DefaultRelMetadataProvider.INSTANCE); return root.rel; }
Example #8
Source File: RelOptTestBase.java From calcite with Apache License 2.0 | 4 votes |
/** * Checks the plan for a SQL statement before/after executing a given rule, * with a pre-program to prepare the tree. * * @param tester Tester * @param preProgram Program to execute before comparing before state * @param planner Planner * @param sql SQL query * @param unchanged Whether the rule is to have no effect */ private void checkPlanning(Tester tester, HepProgram preProgram, RelOptPlanner planner, String sql, boolean unchanged) { final DiffRepository diffRepos = getDiffRepos(); String sql2 = diffRepos.expand("sql", sql); final RelRoot root = tester.convertSqlToRel(sql2); final RelNode relInitial = root.rel; assertNotNull(relInitial); List<RelMetadataProvider> list = new ArrayList<>(); list.add(DefaultRelMetadataProvider.INSTANCE); planner.registerMetadataProviders(list); RelMetadataProvider plannerChain = ChainedRelMetadataProvider.of(list); final RelOptCluster cluster = relInitial.getCluster(); cluster.setMetadataProvider(plannerChain); RelNode relBefore; if (preProgram == null) { relBefore = relInitial; } else { HepPlanner prePlanner = new HepPlanner(preProgram); prePlanner.setRoot(relInitial); relBefore = prePlanner.findBestExp(); } assertThat(relBefore, notNullValue()); final String planBefore = NL + RelOptUtil.toString(relBefore); diffRepos.assertEquals("planBefore", "${planBefore}", planBefore); SqlToRelTestBase.assertValid(relBefore); if (planner instanceof VolcanoPlanner) { relBefore = planner.changeTraits(relBefore, relBefore.getTraitSet().replace(EnumerableConvention.INSTANCE)); } planner.setRoot(relBefore); RelNode r = planner.findBestExp(); if (tester.isLateDecorrelate()) { final String planMid = NL + RelOptUtil.toString(r); diffRepos.assertEquals("planMid", "${planMid}", planMid); SqlToRelTestBase.assertValid(r); final RelBuilder relBuilder = RelFactories.LOGICAL_BUILDER.create(cluster, null); r = RelDecorrelator.decorrelateQuery(r, relBuilder); } final String planAfter = NL + RelOptUtil.toString(r); if (unchanged) { assertThat(planAfter, is(planBefore)); } else { diffRepos.assertEquals("planAfter", "${planAfter}", planAfter); if (planBefore.equals(planAfter)) { throw new AssertionError("Expected plan before and after is the same.\n" + "You must use unchanged=true or call checkUnchanged"); } } SqlToRelTestBase.assertValid(r); }