You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@calcite.apache.org by "Sean Hsuan-Yi Chu (JIRA)" <ji...@apache.org> on 2015/08/12 02:10:46 UTC
[jira] [Created] (CALCITE-841) When the argument of window
functions is an expression, redundant windows could be generated
Sean Hsuan-Yi Chu created CALCITE-841:
-----------------------------------------
Summary: When the argument of window functions is an expression, redundant windows could be generated
Key: CALCITE-841
URL: https://issues.apache.org/jira/browse/CALCITE-841
Project: Calcite
Issue Type: Bug
Reporter: Sean Hsuan-Yi Chu
Assignee: Sean Hsuan-Yi Chu
Firstly of all, this issue happens when HepPlanner is used with ProjectToWindowRule.PROJECT rule.
A query with this pattern:
{code}
select fn(col) over w, fn(expr) over w
from ...
{code}
will generate two "LogicalWindow" even if we have only an identical window frame.
For example,
{code}
select sum(deptno ) over(partition by deptno order by sal) as sum1,
sum(deptno + deptno) over(partition by deptno order by sal) as sum2
from emp
{code}
gives:
{code}
LogicalProject($0=[$2], $1=[$4])
LogicalWindow(window#0=[window(partition {1} order by [0] range between UNBOUNDED PRECEDING and CURRENT ROW aggs [SUM($3)])])
LogicalProject(SAL=[$0], DEPTNO=[$1], $2=[$2], $3=[+($1, $1)])
LogicalProject(SAL=[$5], DEPTNO=[$7], $2=[$9])
LogicalWindow(window#0=[window(partition {7} order by [5] range between UNBOUNDED PRECEDING and CURRENT ROW aggs [SUM($7)])])
LogicalTableScan(table=[[CATALOG, SALES, EMP]])
{code}
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)