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

Roman Churganov updated CALCITE-6983:
-------------------------------------
    Description: 
An issue in `SortJoinTransposeRule` same as in `SortUnionTransposeRule ` has 
fixed in CALCITE-6647 , can be reproduced with a query like 
{code:sql}
           SELECT x.c11 FROM ( 
                     SELECT tt1.c11 FROM (
                                   SELECT c11 FROM sch1.foo as cp1 LIMIT ?
                     ) AS tt1 
                     UNION ALL
                     SELECT tt2.c11 FROM (
                                   SELECT c11 FROM sch1.foo as cp2 LIMIT ?
                      ) AS tt2
            ) AS x    LIMIT ?  
{code}
which hangs on building  a plan, with a debug log can see growing plans, 
eventually it fails with StackOverflow..., 


  was:
A query like 
{code:sql}
           SELECT x.c11 FROM ( 
                     SELECT tt1.c11 FROM (
                                   SELECT c11 FROM sch1.foo as cp1 LIMIT ?
                     ) AS tt1 
                     UNION ALL
                     SELECT tt2.c11 FROM (
                                   SELECT c11 FROM sch1.foo as cp2 LIMIT ?
                      ) AS tt2
            ) AS x    LIMIT ?  
{code}
hangs on building  a plan, with debug log, can see a growing plans with a 
nested LogicalSort nodes, eventually it fails with StackOverflow..., 
{noformat}
       .....
LogicalSort(fetch=[?2])
  LogicalSort(subset=[rel#3740:RelSubset#269.NONE.[]], fetch=[?2])
    LogicalSort(subset=[rel#3670:RelSubset#264.NONE.[]], fetch=[?2])
      LogicalSort(subset=[rel#3600:RelSubset#259.NONE.[]], fetch=[?2])
        LogicalSort(subset=[rel#3530:RelSubset#254.NONE.[]], fetch=[?2])
          LogicalSort(subset=[rel#3460:RelSubset#249.NONE.[]], fetch=[?2])
            LogicalSort(subset=[rel#3390:RelSubset#244.NONE.[]], fetch=[?2])
              LogicalSort(subset=[rel#3320:RelSubset#239.NONE.[]], fetch=[?2])
                LogicalSort(subset=[rel#3250:RelSubset#234.NONE.[]], fetch=[?2])
                  LogicalSort(subset=[rel#3180:RelSubset#229.NONE.[]], 
fetch=[?2])
                    LogicalSort(subset=[rel#3110:RelSubset#224.NONE.[]], 
fetch=[?2])
                      LogicalSort(subset=[rel#3040:RelSubset#219.NONE.[]], 
fetch=[?2])
        ... 
{noformat}
Seem like an issue with  `SortUnionTransposeRule ` 



> SortJoinTransposeRule should not push SORT past a UNION when SORT's fetch is 
> DynamicParam
> -----------------------------------------------------------------------------------------
>
>                 Key: CALCITE-6983
>                 URL: https://issues.apache.org/jira/browse/CALCITE-6983
>             Project: Calcite
>          Issue Type: Bug
>          Components: core
>    Affects Versions: 1.39.0
>            Reporter: Roman Churganov
>            Priority: Blocker
>
> An issue in `SortJoinTransposeRule` same as in `SortUnionTransposeRule ` has 
> fixed in CALCITE-6647 , can be reproduced with a query like 
> {code:sql}
>            SELECT x.c11 FROM ( 
>                      SELECT tt1.c11 FROM (
>                                    SELECT c11 FROM sch1.foo as cp1 LIMIT ?
>                      ) AS tt1 
>                      UNION ALL
>                      SELECT tt2.c11 FROM (
>                                    SELECT c11 FROM sch1.foo as cp2 LIMIT ?
>                       ) AS tt2
>             ) AS x    LIMIT ?  
> {code}
> which hangs on building  a plan, with a debug log can see growing plans, 
> eventually it fails with StackOverflow..., 



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to