You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@calcite.apache.org by "jin xing (Jira)" <ji...@apache.org> on 2019/08/26 05:36:00 UTC
[jira] [Updated] (CALCITE-3292)
SqlToRelConverter#substituteSubQuery fails with NullPointerException when
converting SqlUpdate.
[ https://issues.apache.org/jira/browse/CALCITE-3292?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
jin xing updated CALCITE-3292:
------------------------------
Description:
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.
> 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
>
> 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)