Gleb Kanterov created BEAM-7610:
-----------------------------------

             Summary: SELECT COALESCE(...) isn't inferred as non-nullable field
                 Key: BEAM-7610
                 URL: https://issues.apache.org/jira/browse/BEAM-7610
             Project: Beam
          Issue Type: Bug
          Components: dsl-sql
    Affects Versions: 2.13.0
            Reporter: Gleb Kanterov
            Assignee: Andrew Pilloud


In Calcite, Coalesce is described as:

{code}
ReturnTypes.cascade(ReturnTypes.LEAST_RESTRICTIVE,
            SqlTypeTransforms.LEAST_NULLABLE)
{code}

However, giving non-null constant as an argument doesn't result in a 
non-nullable expression:

{code}
    Schema inputSchema = Schema.of(
        Schema.Field.of("name", Schema.FieldType.STRING.withNullable(true)));

    PCollection<Row> input = p.apply(Create.of(ImmutableList.<Row>of())
        .withCoder(SchemaCoder.of(inputSchema)));

    Schema outputSchema = input
        .apply(SqlTransform.query("SELECT COALESCE(name, 'unknown') as name 
FROM PCOLLECTION"))
        .getSchema();

    assertEquals(
        Schema.builder().addStringField("name").build(),
        outputSchema);
{code}

Not sure if it's a problem in Calcite or Beam SQL.

There are no other functions that can be used to produce a non-nullable field.




--
This message was sent by Atlassian JIRA
(v7.6.3#76005)

Reply via email to