背景:hive 中使用 left join 时,是否可以在 on 条件中中加入限制条件。
结论:不可以,但是在inner join 中是可以的。
create table test.test_no_part (id int ,name string);
insert overwrite table test.test_no_part VALUES (1,'a'),(2,'b'),(3,'c');
create table test.test_no_part_b (id int ,name string);
insert overwrite table test.test_no_part_b VALUES (1,'a'),(2,'b'),(4,'d');
SELECT
t.*,t1.*
from
test.test_no_part t
left join
test.test_no_part_b t1
on t.id =t1.id
;
data:image/s3,"s3://crabby-images/557c7/557c775ca1ff95f070576b5358575ca3d1917dc3" alt=""
?当 on 中加入限制条件时,结果出乎意料。
SELECT
t.*,t1.*
from
test.test_no_part t
left join
test.test_no_part_b t1
on t.id =t1.id and t.id=1
;
?data:image/s3,"s3://crabby-images/c335f/c335f82122ff48533eecb85085a3e0e5e6a7a1b4" alt=""
|