Danny Chen created CALCITE-3379:
-----------------------------------

             Summary: Support expand atom expression in table to relational 
node conversion
                 Key: CALCITE-3379
                 URL: https://issues.apache.org/jira/browse/CALCITE-3379
             Project: Calcite
          Issue Type: Improvement
          Components: core
    Affects Versions: 1.21.0
            Reporter: Danny Chen
            Assignee: Danny Chen
             Fix For: 1.22.0


Now there are 2 ways to convert a RelOptTable to LogicalTableScan:

1. One way is tp open the Config#sConvertTableAccess[1] flag and the 
SqlToRelConverter would invoke the #toRel method which transforms the table to 
a node returned by the user(Usually a table scan).

2. Another way it to use the LogicalTableScan rule, this rule would invoke 
RelOptTable#toRel and wrap the returned node with a LogicalTableScan.

 

The different between 1 and 2 is that, 2 happens in the planning rule but 1 
happens in sql-to-rel conversion, 1 also supports to expand the table columns 
based on the defined default values expressions, see 
InitializerExpressionFactory#newColumnDefaultValue.

 

The problem with the InitializerExpressionFactory#newColumnDefaultValue is that 
it use InitializerContext#convertExpression to convert a SqlNode, if the 
SqlNode is not validated, we always got a RexCall with SqlUnresolvedFunction. 
We should give the user change to validate their SqlNode or even we can support 
pure string expressions because they can be used to persist.

 

Another problem with #toRel is that after the expressions applied as a 
projection, use has no change to apply any other rel nodes if they want, we can 
actually support this, the same way as we support the column expressions.

 

[1]https://github.com/apache/calcite/blob/2dc97e6723e1b5bf762540f87ffffb5cd1a848a1/core/src/main/java/org/apache/calcite/sql2rel/SqlToRelConverter.java#L5605



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

Reply via email to