Class ReplaceIntersectWithSemiJoinRule
- java.lang.Object
-
- org.apache.calcite.plan.RelOptRule
-
- org.apache.calcite.plan.RelRule<ReplaceIntersectWithSemiJoinRule.ReplaceIntersectWithSemiJoinRuleConfig>
-
- org.apache.flink.table.planner.plan.rules.logical.ReplaceIntersectWithSemiJoinRule
-
@Enclosing public class ReplaceIntersectWithSemiJoinRule extends org.apache.calcite.plan.RelRule<ReplaceIntersectWithSemiJoinRule.ReplaceIntersectWithSemiJoinRuleConfig>
Planner rule that replaces distinctIntersect
with a distinctAggregate
on a SEMIJoin
.Only handle the case of input size 2.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static interface
ReplaceIntersectWithSemiJoinRule.ReplaceIntersectWithSemiJoinRuleConfig
Rule configuration.-
Nested classes/interfaces inherited from class org.apache.calcite.plan.RelRule
org.apache.calcite.plan.RelRule.Config, org.apache.calcite.plan.RelRule.Done, org.apache.calcite.plan.RelRule.MatchHandler<R extends org.apache.calcite.plan.RelOptRule>, org.apache.calcite.plan.RelRule.OperandBuilder, org.apache.calcite.plan.RelRule.OperandDetailBuilder<R extends org.apache.calcite.rel.RelNode>, org.apache.calcite.plan.RelRule.OperandTransform
-
-
Field Summary
Fields Modifier and Type Field Description static ReplaceIntersectWithSemiJoinRule
INSTANCE
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description boolean
matches(org.apache.calcite.plan.RelOptRuleCall call)
void
onMatch(org.apache.calcite.plan.RelOptRuleCall call)
-
Methods inherited from class org.apache.calcite.plan.RelOptRule
any, convert, convert, convertList, convertOperand, convertOperand, equals, equals, getOperand, getOperands, getOutConvention, getOutTrait, hashCode, none, operand, operand, operand, operand, operand, operandJ, operandJ, some, toString, unordered
-
-
-
-
Field Detail
-
INSTANCE
public static final ReplaceIntersectWithSemiJoinRule INSTANCE
-
-