[ 
https://issues.apache.org/jira/browse/CALCITE-6877?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17934030#comment-17934030
 ] 

Julian Hyde commented on CALCITE-6877:
--------------------------------------

[~zrlpar], Why were the tests added to RelToSqlConverterTest? They have nothing 
to do with SQL generation. That test has 10,000 lines already.

> Generate LogicalProject in RelRoot.project() when mapping is not name trivial
> -----------------------------------------------------------------------------
>
>                 Key: CALCITE-6877
>                 URL: https://issues.apache.org/jira/browse/CALCITE-6877
>             Project: Calcite
>          Issue Type: Improvement
>          Components: core
>    Affects Versions: 1.38.0
>            Reporter: Niels Pardon
>            Assignee: Niels Pardon
>            Priority: Minor
>              Labels: pull-request-available
>             Fix For: 1.39.0
>
>
> Currently, the RelRoot.project() method only generates a project relation if 
> the RelRoot fields are:
>  * not ref trivial
>  * or if one of the following is not true:
>  ** is not a DML operation
>  ** is not a force project
>  ** the existing top relation is not already a LogicalProject
> [https://github.com/apache/calcite/blob/802fce3c41be76fca899ddb8c856d72c754d1520/core/src/main/java/org/apache/calcite/rel/RelRoot.java#L163-L169]
> The result is that for a simple SQL query that selects a single field from a 
> table and renames the same field we are losing the renaming of the field if 
> we call RelRoot.project() even if we set the force parameter to true since 
> the relational tree embedded in the RelRoot already contains a LogicalProject 
> at the top of the tree.
> My expectation would be that when I call RelRoot.project() that a 
> LogicalProject is being added also if the RelRoot fields are not name trivial 
> aka they are being renamed.



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

Reply via email to