takaaki7 opened a new pull request, #4963: URL: https://github.com/apache/calcite/pull/4963
…EST(array_of_struct) AS alias Under SqlConformanceEnum.BIG_QUERY, SELECT i.name FROM t, UNNEST(t.items) AS i where items is ARRAY<ROW<name ...>> failed validation with "Column 'NAME' not found in table 'I'" because allowAliasUnnestItems() returned false. With the flag off, SqlUnnestOperator#inferReturnType flattens the ROW element type into individual columns instead of keeping it as a single struct-typed column the alias can wrap, and AliasNamespace cannot remap the flattened result back under the alias. BigQuery itself supports this access pattern, so extend the existing PRESTO case in SqlConformanceEnum#allowAliasUnnestItems() to also cover BIG_QUERY. This complements CALCITE-7546, which removes the downstream NPE in SqlToRelConverter#convertUnnest for the 2-operand AS(UNNEST, alias) form when the flag is enabled. <!-- Thanks for sending a pull request! Here are some critical tips for you: 1. READ THE GUIDE FIRST: https://calcite.apache.org/develop/#contributing *For significant contributions, please discuss on the dev mailing list or Jira BEFORE coding.* 2. JIRA IS USUALLY MANDATORY: Ensure you have created an issue on the Calcite Jira: https://issues.apache.org/jira/projects/CALCITE/issues *Check existing issues first to avoid duplicates.* *Note: A Jira is NOT required for typos and cosmetic changes (i.e., changes that are neither bugs nor features).* 3. TIMING: Strongly recommended to create the Jira BEFORE you start writing code (e.g., a day or so before posting a PR). This gives others a chance to weigh in on your specification. 4. CRITICAL CONSISTENCY RULE The following three items MUST match exactly in wording and meaning: (A) The Jira Issue Title (B) This Pull Request Title (C) Your Git Commit Message Format: [CALCITE-XXXX] <Description> Example: [CALCITE-0000] Add IF NOT EXISTS clause to CREATE TABLE Guidelines for a good Title: - Illustrate using SQL keywords (in ALL-CAPS) rather than Java method names. - Focus on the specification and user experience, not the implementation. - Make it clear whether it is a bug or a feature. - Use words like "should" to indicate desired behavior vs. current behavior (e.g., "Validator should not close model file"). 5. REPRODUCTION: If fixing a bug, please provide a concise SQL example or test case to reproduce the issue for a faster review. 6. TESTING: Ensure `./gradlew build` passes and appropriate tests are added/updated. --> ## Jira Link [CALCITE-XXXX](https://issues.apache.org/jira/browse/CALCITE-XXXX) ## Changes Proposed <!-- Please clarify what changes you are proposing. The purpose of this section is to outline the changes and how this PR fixes the issue. If possible, please consider writing useful notes for better and faster reviews in your PR. --> -- 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: [email protected] For queries about this service, please contact Infrastructure at: [email protected]
