phisn opened a new issue, #14358:
URL: https://github.com/apache/datafusion/issues/14358

   ### Is your feature request related to a problem or challenge?
   
   `TableProvider` has a type which indicates which type of table it contains. 
This can be a view. Therefore it makes sense to encode materialised views using 
`TableProvider` and use `TableScan`.
   
   Currently `TableScan` does force the use of one or no `TableReference`. 
Since a view can be derived from multiple tables having the same column names 
it can happen that two columns can only be distinguished by their respective 
`TableReference`.
   
   ### Describe the solution you'd like
   
   `TableScan` should contain unique `table_name: TableReference` for each 
column.
   
   ### Describe alternatives you've considered
   
   Even through `TableScan` contains a `DFSchema` which contains a list of 
`TableReference`, it is not possible to use it since some optimisation rules 
recreate the `TableScan` with the wrong schema.
   
   1. We change the schema in `TableProvider` to `DFSchema` instead of 
`Schema`. I did not test if having multiple same columns in `TableProvider` 
does cause issues which would force this option. As in the execution only the 
column position is important, this seems unlikely.
   2. In my current implementation I am inlining table names using 
`.flat_name()` and outline them again using a analyser rule. Since I can't use 
`TableScan` I am using a custom Extension which is resolved by the analyser too.
   3. Leaving this to the user or creating some new alternative `LogicalPlan` 
node is also possible.
   
   ### Additional context
   
   This feature is slightly related to #14310.


-- 
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: github-unsubscr...@datafusion.apache.org.apache.org

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


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

Reply via email to