[ https://issues.apache.org/jira/browse/CALCITE-3292?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
Haisheng Yuan resolved CALCITE-3292. ------------------------------------ Fix Version/s: 1.21.0 Resolution: Fixed Fixed in https://github.com/apache/calcite/commit/b8d24a6f7f2b4c7cb8093eea158f1fa00dbc6ffc, thanks for the PR, [~jinxing6...@126.com]! > SqlToRelConverter#substituteSubQuery fails with NullPointerException when > converting SqlUpdate. > ----------------------------------------------------------------------------------------------- > > Key: CALCITE-3292 > URL: https://issues.apache.org/jira/browse/CALCITE-3292 > Project: Calcite > Issue Type: Bug > Components: core > Reporter: jin xing > Assignee: jin xing > Priority: Major > Labels: pull-request-available > Fix For: 1.21.0 > > Time Spent: 50m > Remaining Estimate: 0h > > Current code fails below test > {code:java} > // code placeholder > @Test public void testUpdateSubQueryWithIn1() { > final String sql = "update emp\n" > + "set empno = 1 where emp.empno in (\n" > + " select emp.empno from emp where emp.empno=2)"; > sql(sql).ok(); > } > java.lang.NullPointerExceptionjava.lang.NullPointerException at > org.apache.calcite.rel.logical.LogicalJoin.create(LogicalJoin.java:146) at > org.apache.calcite.rel.logical.LogicalJoin.create(LogicalJoin.java:163) at > org.apache.calcite.sql2rel.SqlToRelConverter.substituteSubQuery(SqlToRelConverter.java:1130) > at > org.apache.calcite.sql2rel.SqlToRelConverter.replaceSubQueries(SqlToRelConverter.java:1014) > at > org.apache.calcite.sql2rel.SqlToRelConverter.convertUpdate(SqlToRelConverter.java:3574) > at > org.apache.calcite.sql2rel.SqlToRelConverter.convertQueryRecursive(SqlToRelConverter.java:3176) > at > org.apache.calcite.sql2rel.SqlToRelConverter.convertQuery(SqlToRelConverter.java:563) > at > org.apache.calcite.test.SqlToRelTestBase$TesterImpl.convertSqlToRel(SqlToRelTestBase.java:616) > at > org.apache.calcite.test.SqlToRelTestBase$TesterImpl.assertConvertsTo(SqlToRelTestBase.java:731) > at > org.apache.calcite.test.SqlToRelConverterTest$Sql.convertsTo(SqlToRelConverterTest.java:3601) > at > org.apache.calcite.test.SqlToRelConverterTest$Sql.ok(SqlToRelConverterTest.java:3593) > {code} > In above case, *Subquery* is used as *{{SqlUpdate#condition}}*, when > converting and trying to replace the subquery in *{{SqlUpdate#condition}}*, > *{{BalckBoard#root}}* is *{{null}}* and it makes no sense to do the subquery > substitution. > -- This message was sent by Atlassian Jira (v8.3.2#803003)