You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@impala.apache.org by "Fang-Yu Rao (Jira)" <ji...@apache.org> on 2020/01/08 18:56:00 UTC
[jira] [Created] (IMPALA-9281) Inferred predicates not assigned to
Kudu scan nodes when views are involved
Fang-Yu Rao created IMPALA-9281:
-----------------------------------
Summary: Inferred predicates not assigned to Kudu scan nodes when views are involved
Key: IMPALA-9281
URL: https://issues.apache.org/jira/browse/IMPALA-9281
Project: IMPALA
Issue Type: Bug
Components: Frontend
Affects Versions: Impala 3.4.0
Reporter: Fang-Yu Rao
When a query involves the join of views each created based on multiple Kudu tables, the inferred predicate(s) is(are) not assigned to the Kudu scan node(s). This issue is/seems related to https://issues.apache.org/jira/browse/IMPALA-4578#.
In the following a minimum example to reproduce the phenomenon is given.To create the tables in the provided example below, please replace the address(es) of the Kudu master(s) accordingly.
{code:java}
CREATE TABLE default.t1 (
c1 INT NOT NULL ENCODING AUTO_ENCODING COMPRESSION DEFAULT_COMPRESSION,
c2 STRING NULL ENCODING AUTO_ENCODING COMPRESSION DEFAULT_COMPRESSION,
PRIMARY KEY (c1)
)
PARTITION BY HASH (c1) PARTITIONS 2
STORED AS KUDU
TBLPROPERTIES ('kudu.master_addresses'='10.16.0.115');
insert into t1 values (1, 'one');
CREATE TABLE default.t2 (
c1 INT NOT NULL ENCODING AUTO_ENCODING COMPRESSION DEFAULT_COMPRESSION,
c2 STRING NULL ENCODING AUTO_ENCODING COMPRESSION DEFAULT_COMPRESSION,
PRIMARY KEY (c1)
)
PARTITION BY HASH (c1) PARTITIONS 2
STORED AS KUDU
TBLPROPERTIES ('kudu.master_addresses'='10.16.0.115');
insert into t2 values (2, 'two');
CREATE TABLE default.ta1 (
c1 INT NOT NULL ENCODING AUTO_ENCODING COMPRESSION DEFAULT_COMPRESSION,
c2 STRING NULL ENCODING AUTO_ENCODING COMPRESSION DEFAULT_COMPRESSION,
PRIMARY KEY (c1)
)
PARTITION BY HASH (c1) PARTITIONS 2
STORED AS KUDU
TBLPROPERTIES ('kudu.master_addresses'='10.16.0.115');
insert into ta1 values (1,'one');
CREATE TABLE default.ta2 (
c1 INT NOT NULL ENCODING AUTO_ENCODING COMPRESSION DEFAULT_COMPRESSION,
c2 STRING NULL ENCODING AUTO_ENCODING COMPRESSION DEFAULT_COMPRESSION,
PRIMARY KEY (c1)
)
PARTITION BY HASH (c1) PARTITIONS 2
STORED AS KUDU
TBLPROPERTIES ('kudu.master_addresses'='10.16.0.115');
insert into ta2 values (2,'two');
CREATE VIEW myview_1_on_2_tables AS
SELECT 'ONE' table_source, c1, c2 FROM `default`.t1
UNION ALL
SELECT 'TWO' table_source, c1, c2 FROM `default`.t2;
CREATE VIEW myview_2_on_2_tables AS
SELECT 'ONE' table_source, c1, c2 FROM `default`.ta1
UNION ALL
SELECT 'TWO' table_source, c1, c2 FROM `default`.ta2;
{code}
For easy reference, the contents of tables {{t1}}, {{t2}}, {{ta1}}, {{ta2}}, and views {{myview_1_on_2_tables}}, {{myview_2_on_2_tables}} are also given as follows.
Contents of table {{t1}} afterwards:
{code:java}
+----+-----+
| c1 | c2 |
+----+-----+
| 1 | one |
+----+-----+
{code}
Contents of table {{t2}} afterwards:
{code:java}
+----+-----+
| c1 | c2 |
+----+-----+
| 2 | two |
+----+-----+
{code}
Contents of table {{ta1}} afterwards:
{code:java}
+----+-----+
| c1 | c2 |
+----+-----+
| 1 | one |
+----+-----+
{code}
Contents of table {{ta2}} afterwards:
{code:java}
+----+-----+
| c1 | c2 |
+----+-----+
| 2 | two |
+----+-----+
{code}
Contents in {{default.myview_1_on_2_tables}}:
{code:java}
+--------------+----+-----+
| table_source | c1 | c2 |
+--------------+----+-----+
| ONE | 1 | one |
| TWO | 2 | two |
+--------------+----+-----+
{code}
Contents in {{default.myview_2_on_2_tables}}:
{code:java}
+--------------+----+-----+
| table_source | c1 | c2 |
+--------------+----+-----+
| ONE | 1 | one |
| TWO | 2 | two |
+--------------+----+-----+
{code}
After creating the related tables and views described above, we consider the following 2 queries.
Query 1:
{code:java}
select count(*)
from default.myview_1_on_2_tables a, myview_2_on_2_tables b
where a.table_source = 'ONE'
and a.table_source = b.table_source
and a.c2 = 'one';
{code}
Query 2:
{code:java}
select count(*)
from default.myview_1_on_2_tables a, myview_2_on_2_tables b
where a.table_source = 'ONE'
and b.table_source = 'ONE'
and a.table_source = b.table_source
and a.c2 = 'one';
{code}
Both queries join those 2 views on the column {{table_source}} and filter out those rows not satisfying {{table_source = 'ONE'}}. Both queries produce the same result set as the following.
{code:java}
+----------+
| count(*) |
+----------+
| 1 |
+----------+
{code}
However, according to the query profile, Query 1 results in 3 Kudu scans on tables {{t1}}, {{ta1}}, and {{ta2}}, respectively. On the other hand, Query 2 that incorporates the additional/redundant predicate "{{b.table_source = 'ONE}}'" only involves 2 Kudu scans on tables {{t1}} and {{ta1}}, respectively due to this seemingly redundant predicate on {{b.table_source}}.
Hence, it can be seen that the plan generated from Query 1 is sub-optimal since a table that cannot contain any row in the result set is still scanned, i.e., table {{ta2}}.
--
This message was sent by Atlassian Jira
(v8.3.4#803005)