Timo Walther created FLINK-5677:
-----------------------------------

             Summary: Validation layer should check whether field can be used 
as grouping key
                 Key: FLINK-5677
                 URL: https://issues.apache.org/jira/browse/FLINK-5677
             Project: Flink
          Issue Type: Improvement
          Components: Table API & SQL
            Reporter: Timo Walther


When grouping on a GenericType (e.g. {{Object}}). The validation layer does no 
checking of types. The {{groupBy/keyBy}} of DataSet/DataStream API throws the 
exception. The validation layer should check this before.

{code}
public static class OuterPojo {
        public Object object = new Object();
}
tEnv.sql("SELECT testing.object FROM testing GROUP BY testing.object")
{code}

leads to 
{code}
Exception in thread "main" org.apache.flink.api.common.InvalidProgramException: 
This type (GenericType<java.lang.Object>) cannot be used as key.
        at 
org.apache.flink.api.common.operators.Keys$ExpressionKeys.<init>(Keys.java:270)
        at 
org.apache.flink.api.common.operators.Keys$ExpressionKeys.<init>(Keys.java:223)
        at org.apache.flink.api.java.DataSet.groupBy(DataSet.java:692)
        at 
org.apache.flink.table.plan.nodes.dataset.DataSetAggregate.translateToPlan(DataSetAggregate.scala:134)
        at 
org.apache.flink.table.api.BatchTableEnvironment.translate(BatchTableEnvironment.scala:305)
        at 
org.apache.flink.table.api.BatchTableEnvironment.translate(BatchTableEnvironment.scala:289)
        at 
org.apache.flink.table.api.java.BatchTableEnvironment.toDataSet(BatchTableEnvironment.scala:146)

{code}



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

Reply via email to