[
https://issues.apache.org/jira/browse/FLINK-39799?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
ASF GitHub Bot updated FLINK-39799:
-----------------------------------
Labels: pull-request-available (was: )
> Preserve user-typed query text for materialized table and view definitions
> --------------------------------------------------------------------------
>
> Key: FLINK-39799
> URL: https://issues.apache.org/jira/browse/FLINK-39799
> Project: Flink
> Issue Type: Bug
> Components: Table SQL / API
> Reporter: Ramin Gharib
> Priority: Major
> Labels: pull-request-available
>
> When a {{{}CREATE MATERIALIZED TABLE … AS …{}}}, {{{}ALTER MATERIALIZED TABLE
> … AS …{}}}, or {{CREATE VIEW … AS …}} statement is converted to a catalog
> object, the persisted {{originalQuery}} is currently produced by re-rendering
> the parsed {{SqlNode}} via {{SqlNode#toSqlString()}} (through
> {{{}ConvertContext#toQuotedSqlString{}}}). This normalizes the user's input:
> identifier casing is changed, type aliases are expanded ({{{}int{}}} →
> {{{}INTEGER{}}}), whitespace is reformatted, and quoting style is rewritten.
> As a result, {{SHOW CREATE MATERIALIZED TABLE}} / {{SHOW CREATE VIEW}} and
> round-trips through the catalog no longer reflect what the user typed, even
> though the field is named {{{}originalQuery{}}}.
> h2. Example
> User input:
> {code:java}
> CREATE MATERIALIZED TABLE mt AS SELECT a, b, cast(c as int) as int_c FROM t1
> WHERE c > 200 {code}
>
>
> Currently persisted {{{}originalQuery{}}}:
>
>
> {code:java}
> SELECT `a`, `b`, CAST(`c` AS INTEGER) AS `int_c` FROM `t1` WHERE `c` >
> 200{code}
>
>
> Desired:
>
> {code:java}
> SELECT a, b, cast(c as int) as int_c FROM t1 WHERE c > 200{code}
> The {{expandedQuery}} field is unchanged; it continues to hold the
> fully-qualified, normalized form used by the planner.
> h2. Acceptance criteria
> * {{originalQuery}} on {{CatalogMaterializedTable}} and {{CatalogView}}
> equals the verbatim substring the user typed for the AS-query.
> * {{expandedQuery}} remains the planner-normalized form.
> * {{SHOW CREATE MATERIALIZED TABLE}} / {{SHOW CREATE VIEW}} reflect the
> user's original wording.
> * Existing planner tests are updated where they asserted the normalized form.
--
This message was sent by Atlassian Jira
(v8.20.10#820010)