hive join

join关键字默认为内连接,返回两张表中都有的信息;

left join以前面的表作为主表和其他表进行关联,返回的记录数和主表的记录数相同,关联不上的字段用NULL;

right join与left相反,以后面的表为主表,和前面的表做关联,返回的记录数和主表一致,关联不上的字段为NULL;

full join为全关联,返回两个表记录的并集,关联不上的字段为NULL;

left semi join以关键字前面的表为主表,两个表对on的条件字段做交集,返回前面表的记录;

cross join(笛卡尔积关联)返回两个表的笛卡尔积结果,不需要指定关联键;

 

由于Mysql的写法在hive中会出错,改成下面的就可以了

mysql写法:
SELECT
ename,sal
FROM
emp e1
where sal > (
SELECT
avg(sal)
FROM
emp
)
ORDER BY e1.sal desc

hive写法: 
cross join 可以不加连接条件
select ENAME,SAL 
from 
(select avg(SAL) as avgSAL from emp) a 
cross join
emp b 
where SAL > avgSAL
order by SAL desc;

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值