hive同步hbase数据报错 columns has 10elements while hbase.columns.mapping has 11 elements

2021-01-26 11:11:04 浏览数 (1)

今天做hive建表数据同步hbase时报了下面这个异常。

翻译过来大致就是hbase中有11个字段,而hive中只有10个字段,很明显需要同步数据的两个表的字段数不一致!

但问题可没有简单!

在反复确认业务需求的字段数为10个,我就开始纳闷了为啥异常中总说Hbase中有11个字段?

后来查了多方资料后终于得出了答案:

在创建hive/hbase相关联的表时,hbase表结构默认会有一个字段key,如果没有一个显示的字段’key’那么在创建表的进修,会自己创建,这样hive对应的表就会出现问题,所以在hive对应的表里一定要加上key这个字段,为了避免这个问题,在hbase表结构里可以显示的添加’key’字段,这样不容易出问题。

所以我们在创建的hive表中再加一个string 类型的 key就好了٩(๑❛ᴗ❛๑)۶

0 人点赞