Aleksey Plekhanov created IGNITE-25357:
------------------------------------------

             Summary: Calcite engine. Wrong required columns calculation for 
double correlate
                 Key: IGNITE-25357
                 URL: https://issues.apache.org/jira/browse/IGNITE-25357
             Project: Ignite
          Issue Type: Bug
            Reporter: Aleksey Plekhanov


Reproducer:
{code:java}
    /** */
    @Test
    public void testCorrelateWrongRequiredColumn() throws Exception {
        IgniteSchema schema = createSchema(
            createTable("T1", IgniteDistributions.single(), "ID", 
Integer.class, "NAME", String.class, "REF", Integer.class),
            createTable("T2", IgniteDistributions.single(), "ID", 
Integer.class, "REF", Integer.class),
            createTable("T3", IgniteDistributions.single(), "ID", 
Integer.class, "REF", Integer.class)
        );

        assertPlan("SELECT T1.NAME FROM T1 " +
                "WHERE EXISTS (" +
                "   SELECT 1 " +
                "   FROM T2 " +
                "   WHERE T2.ID = T1.REF AND T2.REF = (SELECT 1 FROM T3 WHERE 
T3.ID = T1.REF)" +
                ")", schema,
            nodeOrAnyChild(isTableScan("T1")));   
    }
{code}
 Throws an assertion error:
{noformat}
 java.lang.AssertionError: Required columns {2} not subset of left columns {0, 
1}
        at org.apache.calcite.util.Litmus.lambda$static$0(Litmus.java:31) 
~[calcite-core-1.37.0.jar:1.37.0]
        at org.apache.calcite.util.Litmus.check(Litmus.java:76) 
~[calcite-core-1.37.0.jar:1.37.0]
        at org.apache.calcite.rel.core.Correlate.isValid(Correlate.java:145) 
~[calcite-core-1.37.0.jar:1.37.0]
        at org.apache.calcite.rel.core.Correlate.<init>(Correlate.java:109) 
~[calcite-core-1.37.0.jar:1.37.0]
        at 
org.apache.calcite.rel.logical.LogicalCorrelate.<init>(LogicalCorrelate.java:73)
 ~[calcite-core-1.37.0.jar:1.37.0]
        at 
org.apache.calcite.rel.logical.LogicalCorrelate.create(LogicalCorrelate.java:116)
 ~[calcite-core-1.37.0.jar:1.37.0]
{noformat}


 



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to