Hive 数据关联操作

Hive 支持通常的 SQL JOIN 语句,但是只支持等值连接,不支持非等值连接。
意思就是只能join1.id=join2.id不可以是join1.id!=join2.id或者join1.id>join2.id之类的

在hive中,关联有4种方式:

内关联:join on
左外关联:left join on
右外关联:right join on
全外关联:full join on
另外还有一种可实现hive笛卡儿积的效果(hive不支持笛卡儿积): 在on后面接为true的表达式,如on 1=1(需先设置非严格模式:set hive.mapred.mode=nonstrict);

如我有两个表:join1和join2,如下

 

内关联:
select * from jion1 join join2 on jion1.id = jion2.id;

通常我们可以通过取别名的方式来进行关联,选取我们想要的字段,如:

select a.id,a.name,a.sex,a.addr,b.age from join1 a join join2 b on a.id=b.id;

作用:将表1和表2的字段id相同的内容 关联到一个表里。

效果如下:

左外连接:

select * from jion1 left join join2 on jion1.id = jion2.id;

作用:以join左边的表为标准进行连接(即保留左边表的字段值,右边表不符合on条件的用null表示)。

效果如下:

右外连接:

select * from jion1 right join join2 on jion1.id = jion2.id;

作用:以join右边的表为标准进行连接(即保留右边表的字段值,左边表不符合on条件的用null表示)。

效果如下:

全外连接:

select * from jion1 full join join2 on jion1.id = jion2.id;

作用:两个表连接,表留所有字段的值,不符合on条件的用null表示。

效果如下:

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Hive是一个基于Hadoop的数据仓库架构​​,可以用于处理大数据量的结构化和半结构化数据。拉链表是一种常用于历史数据关联分析的技术。下面我将简要介绍如何在Hive中使用拉链表来关联历史数据。 拉链表是一种用于处理数据随时间变动的关联关系的表设计方法。它通常包含两个重要的字段:生效日期和失效日期。生效日期表示了某个数据的开始日期,失效日期表示了该数据的结束日期。 在Hive中,我们可以使用窗口函数和联接操作来实现拉链表的历史数据关联。首先,我们需要在数据表中添加生效日期和失效日期字段,并将历史数据按照日期排序。然后,我们可以使用窗口函数来为每一行数据分配一个唯一的行号,并根据行号对历史数据进行版本化。接下来,我们可以使用联接操作将历史数据和当前数据关联起来,以便进行历史数据的查询和分析。 例如,我们有一个学生表student,其中包含学生的信息,还有一个历史变动表student_history,用于记录学生信息的变动。我们可以使用拉链表的方式将学生表和学生历史变动表进行关联。 首先,我们可以在student表和student_history表中添加生效日期和失效日期字段,并将数据按照日期排序。然后,我们使用窗口函数为每一行数据分配一个唯一的行号,并对学生历史变动表进行版本化。 接下来,我们可以使用联接操作将学生表和学生历史变动表进行关联,以便查询某个时间点学生的信息以及变动情况。例如,我们可以查询某个日期范围内学生的姓名、年龄以及变动情况。 在Hive中,使用拉链表来关联历史数据可以提供更加全面和准确的历史数据分析。通过使用窗口函数和联接操作,我们可以轻松地实现拉链表的历史数据关联
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值