Robin Trietsch created BEAM-4114: ------------------------------------ Summary: Allow null as leftNullValue/rightNullValue in Join.fullOuterJoin() Key: BEAM-4114 URL: https://issues.apache.org/jira/browse/BEAM-4114 Project: Beam Issue Type: Improvement Components: sdk-java-core Affects Versions: 2.4.0 Reporter: Robin Trietsch Assignee: Kenneth Knowles
When using the [Join.fullOuterJoin()|https://beam.apache.org/documentation/sdks/javadoc/2.4.0/org/apache/beam/sdk/extensions/joinlibrary/Join.html#fullOuterJoin-org.apache.beam.sdk.values.PCollection-org.apache.beam.sdk.values.PCollection-V1-V2-], a checkNotNull() is done for the [leftNullValue|https://github.com/apache/beam/blob/master/sdks/java/extensions/join-library/src/main/java/org/apache/beam/sdk/extensions/joinlibrary/Join.java#L207] and [rightNullValue|https://github.com/apache/beam/blob/master/sdks/java/extensions/join-library/src/main/java/org/apache/beam/sdk/extensions/joinlibrary/Join.java#L208]. However, it makes more sense to allow null values, since sometimes, if the key used for the join is not the same, you'd like to see that the value will become null. This should be decided by the developer, and not by the join library. Looking at the source code, this is also supported by [KV.of()|https://github.com/apache/beam/blob/master/sdks/java/core/src/main/java/org/apache/beam/sdk/values/KV.java#L42] (it allows null values), which is used in Join.fullOuterJoin(). -- This message was sent by Atlassian JIRA (v7.6.3#76005)