sohardforaname opened a new pull request, #17968:
URL: https://github.com/apache/doris/pull/17968

   # Proposed changes
   
   Issue Number: close #xxx
   
   ## Problem summary
   
   SQL like TPC-H Q2 and Q17, which contains a correlated sub-query with only 
one aggregation function output, we can eliminate the sub-query and transform 
it to window function. For example, TPC-H Q17 is
   select
           sum(l_extendedprice) / 7.0 as avg_yearly
       from
           lineitem,
           part
       where
           p_partkey = l_partkey
           and p_brand = 'Brand#23'
           and p_container = 'MED BOX'
           and l_quantity < (
               select
                   0.2 * avg(l_quantity)
               from
                   lineitem
               where
                   l_partkey = p_partkey
           );
   
   we change it to
   
   select
           sum(l_extendedprice) / 7.0 as avg_yearly
       from (
       select
           l_extendedprice, l_quantity, 0.2 * avg(l_quantity) over(partition by 
l_partkey) avg_l_quantity
       from 
           lineitem,
           part
       where
           p_partkey = l_partkey
           and p_brand = 'Brand#23'
           and p_container = 'MED BOX' )
       where l_quantity < avg_l_quantity
   
   
   ## Checklist(Required)
   
   * [ ] Does it affect the original behavior
   * [ ] Has unit tests been added
   * [ ] Has document been added or modified
   * [ ] Does it need to update dependencies
   * [ ] Is this PR support rollback (If NO, please explain WHY)
   
   ## Further comments
   
   If this is a relatively large or complex change, kick off the discussion at 
[d...@doris.apache.org](mailto:d...@doris.apache.org) by explaining why you 
chose the solution you did and what alternatives you considered, etc...
   
   


-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: commits-unsubscr...@doris.apache.org

For queries about this service, please contact Infrastructure at:
us...@infra.apache.org


---------------------------------------------------------------------
To unsubscribe, e-mail: commits-unsubscr...@doris.apache.org
For additional commands, e-mail: commits-h...@doris.apache.org

Reply via email to