Jesus Camacho Rodriguez created HIVE-17040: ----------------------------------------------
Summary: Join elimination in the presence of FK relationship Key: HIVE-17040 URL: https://issues.apache.org/jira/browse/HIVE-17040 Project: Hive Issue Type: Sub-task Components: Logical Optimizer Affects Versions: 3.0.0 Reporter: Jesus Camacho Rodriguez If the PK/UK table is not filtered, we can safely remove the join. A simple example: {code:sql} SELECT c_current_cdemo_sk FROM customer, customer_address ON c_current_addr_sk = ca_address_sk; {code} As a Calcite rule, we could implement this rewriting by 1) matching a Project on top of a Join operator, 2) checking that only columns from the FK are used in the Project, 3) checking that the join condition matches the FK - PK/UK relationship, 4) pulling all the predicates from the PK/UK side and checking that the input is not filtered, and 5) removing the join, possibly adding a IS NOT NULL condition on the join column from the FK side. If the PK/UK table is filtered, we should still transform the Join into a SemiJoin operator. -- This message was sent by Atlassian JIRA (v6.4.14#64029)