org.apache.hyracks.algebricks.core.rewriter.base.IAlgebraicRewriteRulepublic class EliminateUnnestAggregateSubplanRule extends Object implements org.apache.hyracks.algebricks.core.rewriter.base.IAlgebraicRewriteRule
Before
%PARENT_PLAN
UNNEST( $v2 : iterate( $v1 ) )
SUBPLAN{
AGGREGATE( $v1 : sequence( %expression ) )
%NESTED_PLAN
NESTEDTUPLESOURCE
}
%CHILD_PLAN
where %PARENT_PLAN does not use $v1.
After
%PARENT_PLAN
UNNEST( $v2 : iterate( $v3 ) )
ASSIGN( $v3 : %expression )
%NESTED_PLAN
%CHILD_PLAN
| Constructor | Description |
|---|---|
EliminateUnnestAggregateSubplanRule() |
| Modifier and Type | Method | Description |
|---|---|---|
boolean |
rewritePost(org.apache.commons.lang3.mutable.Mutable<org.apache.hyracks.algebricks.core.algebra.base.ILogicalOperator> opRef,
org.apache.hyracks.algebricks.core.algebra.base.IOptimizationContext context) |
|
boolean |
rewritePre(org.apache.commons.lang3.mutable.Mutable<org.apache.hyracks.algebricks.core.algebra.base.ILogicalOperator> opRef,
org.apache.hyracks.algebricks.core.algebra.base.IOptimizationContext context) |
public boolean rewritePre(org.apache.commons.lang3.mutable.Mutable<org.apache.hyracks.algebricks.core.algebra.base.ILogicalOperator> opRef,
org.apache.hyracks.algebricks.core.algebra.base.IOptimizationContext context)
throws org.apache.hyracks.algebricks.common.exceptions.AlgebricksException
rewritePre in interface org.apache.hyracks.algebricks.core.rewriter.base.IAlgebraicRewriteRuleorg.apache.hyracks.algebricks.common.exceptions.AlgebricksExceptionpublic boolean rewritePost(org.apache.commons.lang3.mutable.Mutable<org.apache.hyracks.algebricks.core.algebra.base.ILogicalOperator> opRef,
org.apache.hyracks.algebricks.core.algebra.base.IOptimizationContext context)
rewritePost in interface org.apache.hyracks.algebricks.core.rewriter.base.IAlgebraicRewriteRuleCopyright © 2019 Apache Software Foundation. All rights reserved.