291294878

2018-10-19   阅读量: 6419

大数据 Hive

JOIN ON后面能不能接OR?

扫码加入数据分析学习群

join on后面的条件可以加and,但是不能加or。怎么理解呢?join on后面接的本来应该是一个连接条件,如果加and的话,我们可以理解为让连接条件更加严谨,但是加or的话会出现报错,因为on是最基本的连接条件,放宽连接条件的话,join就会无法完成。以下是错误示范:

select t1.a,t1.b,t2.a,t2.b

from t1

left outer join t2

on t1.a = t2.a

or t1.b = t2.b

可如果我就是想多join一些结果出来,有没有替代方案呢?有的,就是union all

select t1.a,t1.b,t2.a,t2.b

from

(select t1.a,t1.b,t2.a,t2.b from t1

left outer join t2

on t1.a = t2.a

union all

select t1.a,t1.b,t2.a,t2.b from t1

left outer join t2

on t1.b = t2.b) tmp

添加CDA认证专家【维克多阿涛】,微信号:【cdashijiazhuang】,提供数据分析指导及CDA考试秘籍。已助千人通过CDA数字化人才认证。欢迎交流,共同成长!
0.0000 0 3 关注作者 收藏

评论(0)


暂无数据

推荐课程

推荐帖子