Jingsong Lee created FLINK-17922:
------------------------------------
Summary: Refactor generic and hive table rules for HiveCatalog
Key: FLINK-17922
URL: https://issues.apache.org/jira/browse/FLINK-17922
Project: Flink
Issue Type: Bug
Components: Connectors / Hive
Reporter: Jingsong Lee
Fix For: 1.12.0
Now the underlying rules are:
* HiveCatalog.createTable , hive table has false of {{isGeneric}} flag,
generic table has no flag.
* HiveCatalog.getTable , generic table has true of {{isGeneric}} flag, hive
table has no flag.
It is very difficult to understand and easy to cause bugs.
Whether it's {{createTable}} or {{getTable}} of {{HiveCatalog}}, there should
be two types of objects that are consistent: {{HiveCatalogTable}} and Flink
{{CatalogTableImpl}}.
Timo: From a logical perspective, the {{HiveCatalog}} should deal with this
additional property while storing and retrieving a {{CatalogTable}}. The
{{isGeneric}} should not travel through the stack of regular Flink connector
options. It is an internal property from the {{HiveCatalog}} through a custom
{{HiveCatalogTable}} to a custom {{HiveFactory}}. It should be stored as a
member variable in a {{HiveCatalogTable}}.
--
This message was sent by Atlassian Jira
(v8.3.4#803005)