[ 
https://issues.apache.org/jira/browse/CALCITE-4609?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Julian Hyde resolved CALCITE-4609.
----------------------------------
    Fix Version/s: 1.27.0
       Resolution: Fixed

Fixed in 
[c96d85cc|https://github.com/apache/calcite/commit/c96d85ccad32cbdc9b52b5e2488887ed14a1b5ec].

> AggregateRemoveRule throws while handling AVG
> ---------------------------------------------
>
>                 Key: CALCITE-4609
>                 URL: https://issues.apache.org/jira/browse/CALCITE-4609
>             Project: Calcite
>          Issue Type: Bug
>            Reporter: Julian Hyde
>            Assignee: Julian Hyde
>            Priority: Major
>             Fix For: 1.27.0
>
>
> A {{WITH}} query using AVG throws {{AssertionError: type mismatch}}. The query
> {code:sql}
> WITH EmpAnalytics AS (
>   SELECT deptno, job, AVG(sal) AS avg_sal
>   FROM Emp
>   GROUP BY deptno, job)
> SELECT job, avg(avg_sal) AS avg_sal2
> FROM EmpAnalytics
> WHERE deptno = 30
> GROUP BY job{code}
> gives error
> {noformat}
> java.lang.AssertionError: type mismatch:
> ref:
> DECIMAL(19, 2)
> input:
> DECIMAL(7, 2)
>       at org.apache.calcite.util.Litmus$1.fail(Litmus.java:32)
>       at org.apache.calcite.plan.RelOptUtil.eq(RelOptUtil.java:2209)
>       at org.apache.calcite.rex.RexChecker.visitInputRef(RexChecker.java:129)
>       at org.apache.calcite.rex.RexChecker.visitInputRef(RexChecker.java:61)
>       at org.apache.calcite.rex.RexInputRef.accept(RexInputRef.java:114)
>       at org.apache.calcite.rel.core.Project.isValid(Project.java:219)
>       at org.apache.calcite.rel.core.Project.<init>(Project.java:98)
>       at 
> org.apache.calcite.rel.logical.LogicalProject.<init>(LogicalProject.java:69)
>       at 
> org.apache.calcite.rel.logical.LogicalProject.create(LogicalProject.java:126)
>       at 
> org.apache.calcite.rel.logical.LogicalProject.create(LogicalProject.java:114)
>       at 
> org.apache.calcite.rel.core.RelFactories$ProjectFactoryImpl.createProject(RelFactories.java:178)
>       at org.apache.calcite.tools.RelBuilder.project_(RelBuilder.java:1645)
>       at org.apache.calcite.tools.RelBuilder.project(RelBuilder.java:1417)
>       at org.apache.calcite.tools.RelBuilder.project(RelBuilder.java:1389)
>       at org.apache.calcite.tools.RelBuilder.project(RelBuilder.java:1378)
>       at 
> org.apache.calcite.rel.rules.AggregateRemoveRule.onMatch(AggregateRemoveRule.java:120)
> {noformat}
> Here is a patch that reproduces:
> {noformat}
> diff --git a/core/src/test/resources/sql/misc.iq 
> b/core/src/test/resources/sql/misc.iq
> index ba5ce1053..d036da3d2 100644
> --- a/core/src/test/resources/sql/misc.iq
> +++ b/core/src/test/resources/sql/misc.iq
> @@ -1065,6 +1065,16 @@ Expression 'DEPTNO' is not being grouped
>  
>  !use scott
>  
> +WITH EmpAnalytics as (
> +  SELECT deptno, job, AVG(sal) AS avg_sal
> +  FROM "scott".emp
> +  GROUP BY deptno, job)
> +SELECT job, AVG(avg_sal) AS avg_sal2
> +FROM EmpAnalytics
> +WHERE deptno = 30
> +GROUP BY job;
> +!ok
> +
>  # ORDER BY expression with SELECT DISTINCT
>  select distinct deptno, job
>  from "scott".emp
> {noformat}
> If you run the same query from SQLLine, you get a different error, but I 
> think they are probably related:
> {noformat}
> Error while applying rule ProjectMergeRule, args 
> [rel#406:LogicalProject.NONE.[](input=RelSubset#301,exprs=[$1, $2, CASE(IS 
> NOT NULL($2), 1:BIGINT, 0:BIGINT)]), 
> rel#362:LogicalProject.NONE.[](input=RelSubset#361,exprs=[$1, $0, $2])] 
> (state=,code=0)
> {noformat}



--
This message was sent by Atlassian Jira
(v8.3.4#803005)

Reply via email to