Fabian Hueske created FLINK-3848:
------------------------------------
Summary: Add ProjectableTableSource interface and translation rule
Key: FLINK-3848
URL:
https://issues.apache.org/jira/browse/FLINK-3848 Project: Flink
Issue Type: Task
Components: Table API
Reporter: Fabian Hueske
Add a {{ProjectableTableSource}} interface that {{TableSource}}s can implement which support projection.
The interface could look as follows
{code}
def trait ProjectableTableSource {
def setProjection(fields: Array[String]): Unit
}
{code}
In addition we need Calcite rules to push a projection into a TableScan that refers to a {{ProjectableTableSource}}. We might need to tweak the cost model as well to push the optimizer in the right direction.
Moreover, the {{CsvTableSource}} could be extended to implement {{ProjectableTableSource}}.
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)