[
https://issues.apache.org/jira/browse/FLINK-7730?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=16205613#comment-16205613
]
ASF GitHub Bot commented on FLINK-7730:
---------------------------------------
GitHub user xccui opened a pull request:
https://github.com/apache/flink/pull/4830
[FLINK-7730] [table] Restrict the predicates of table function left outer
join
## What is the purpose of the change
The PR aims to temporarily cover up the table function left outer join
problem by adding restrictions on the join predicates.
## Brief change log
- Predicates check for table function left outer join (correlate) are
added to `DataSetCalcRule` and `DataStreamCalcRule`.
- Update related tests.
- Refine the documents.
## Verifying this change
This change is already covered by existing tests, such as `CorrelateITCase`
and `CorrelateTest`.
## Does this pull request potentially affect one of the following parts:
- Dependencies (does it add or upgrade a dependency): (no)
- The public API, i.e., is any changed class annotated with
`@Public(Evolving)`: (no)
- The serializers: (no)
- The runtime per-record code paths (performance sensitive): (no)
- Anything that affects deployment or recovery: JobManager (and its
components), Checkpointing, Yarn/Mesos, ZooKeeper: (no)
## Documentation
- Does this pull request introduce a new feature? (no)
- If yes, how is the feature documented? (docs)
You can merge this pull request into a Git repository by running:
$ git pull https://github.com/xccui/flink FLINK-7730
Alternatively you can review and apply these changes as the patch at:
https://github.com/apache/flink/pull/4830.patch
To close this pull request, make a commit to your master/trunk branch
with (at least) the following in the commit message:
This closes #4830
----
commit 58d2635877f76937cc23d97fe1aa1da8ff51ebd7
Author: Xingcan Cui <[email protected]>
Date: 2017-10-16T08:49:14Z
[FLINK-7730] [table] Add restrictions on table function left outer join
----
> TableFunction LEFT OUTER joins with ON predicates are broken
> ------------------------------------------------------------
>
> Key: FLINK-7730
> URL: https://issues.apache.org/jira/browse/FLINK-7730
> Project: Flink
> Issue Type: Bug
> Components: Table API & SQL
> Affects Versions: 1.4.0, 1.3.2
> Reporter: Fabian Hueske
> Assignee: Xingcan Cui
> Priority: Critical
>
> TableFunction left outer joins with predicates in the ON clause are broken.
> Apparently, the are no tests for this and it has never worked. I observed
> issues on several layers:
> - Table Function does not correctly validate equality predicate:
> {{leftOuterJoin(func1('c) as 'd, 'a.cast(Types.STRING) === 'd)}} is rejected
> because the predicate is not considered as an equality predicate (the cast
> needs to be pushed down).
> - Plans cannot be correctly translated: {{leftOuterJoin(func1('c) as 'd, 'c
> === 'd)}} gives an optimizer exception.
> - SQL queries get translated but produce incorrect results. For example
> {{SELECT a, b, c, d FROM MyTable LEFT OUTER JOIN LATERAL TABLE(tfunc(c)) AS
> T(d) ON d = c}} returns an empty result if the condition {{d = c}} never
> returns true. However, the outer side should be preserved and padded with
> nulls.
> So there seem to be many issues with table function outer joins. Especially,
> the wrong result produced by SQL queries need to be quickly fixed.
--
This message was sent by Atlassian JIRA
(v6.4.14#64029)