[ https://issues.apache.org/jira/browse/FLINK-37814?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
Gustavo de Morais updated FLINK-37814: -------------------------------------- Summary: FLIP-516: Add RIGHT JOIN to LEFT JOIN rule (was: FLIP-516: Adjust FlinkJoinToMultiJoinRule for Multi Join Operator) > FLIP-516: Add RIGHT JOIN to LEFT JOIN rule > ------------------------------------------ > > Key: FLINK-37814 > URL: https://issues.apache.org/jira/browse/FLINK-37814 > Project: Flink > Issue Type: Sub-task > Reporter: Gustavo de Morais > Priority: Major > > The current FlinkJoinToMultiJoinRule is implemented and only used for join > reordering. We can use it as a base but we need a new set of optimizer rules > for the multi way join operator: > * Add right join to left join rule - our operator only works with left joins > * -Add FlinkLogicalMultiJoin with all parameters we need + > FlinkJoinToFlinkMultiJoinRule to create it- > ** -There are some parameters that calcite's MultiJoin does not contain as > we require it. For example: we only have outerJoinConditions and we actually > need all join conditions for each input level, including inner joins.- > * -Check if the join chain respects the multi join common key restrictions- > ** -If not, create one multi join for each group of joins that respect. That > means 9 chained joins, 3 have one common key and 6 have another will generate > two chained multi joins.- > > Update: I'll split all these optimizer changes into multiple smaller tickets > to make it easier to iterate and review. This ticket will be used to address > the RIGHT JOIN to LEFT JOIN rule rule. -- This message was sent by Atlassian Jira (v8.20.10#820010)