Stamatis Zampetakis created CALCITE-4560:
--------------------------------------------
Summary: Wrong plan when decorrelating EXISTS subquery with
COALESCE in the predicate
Key: CALCITE-4560
URL: https://issues.apache.org/jira/browse/CALCITE-4560
Project: Calcite
Issue Type: Bug
Components: core
Affects Versions: 1.27.0
Reporter: Stamatis Zampetakis
The problem can be seen by adding the following test in
{{SqlToRelConverterTest}}.
{code:java}
@Test void testExistsCorrelatedDecorrelate01() {
final String sql = "select e1.empno from empnullables e1 where exists (\n"
+ " select 1 from empnullables e2 where
COALESCE(e1.ename,'M')=COALESCE(e2.ename,'M'))";
sql(sql).decorrelate(true).ok();
}
{code}
The plan after decorrelation is shown below:
{noformat}
LogicalProject(EMPNO=[$0])
LogicalProject(EMPNO=[$0], ENAME=[$1], JOB=[$2], MGR=[$3], HIREDATE=[$4],
SAL=[$5], COMM=[$6], DEPTNO=[$7], SLACKER=[$8], ENAME0=[$9],
$f1=[CAST($10):BOOLEAN])
LogicalJoin(condition=[=($1, $9)], joinType=[inner])
LogicalTableScan(table=[[CATALOG, SALES, EMPNULLABLES]])
LogicalAggregate(group=[{0}], agg#0=[MIN($1)])
LogicalProject(ENAME0=[$9], $f0=[true])
LogicalJoin(condition=[=(CASE(IS NOT NULL($9), $9, 'M':VARCHAR(20)),
CASE(IS NOT NULL($1), CAST($1):VARCHAR(20) NOT NULL, 'M':VARCHAR(20)))],
joinType=[inner])
LogicalTableScan(table=[[CATALOG, SALES, EMPNULLABLES]])
LogicalAggregate(group=[{0}])
LogicalProject(ENAME=[$1])
LogicalTableScan(table=[[CATALOG, SALES, EMPNULLABLES]])
{noformat}
The problem lies in the {{LogicalJoin(condition=[=($1, $9)],
joinType=[inner])}} operator. If there are rows with {{NULL}} values in the
{{ENAME}} column these are going to be incorrectly removed from the result set.
The COALESCE operator is present in the SQL query to ensure that rows with NULL
values are retained in the result.
--
This message was sent by Atlassian Jira
(v8.3.4#803005)