今天做hive建表数据同步hbase时报了下面这个异常。
翻译过来大致就是hbase中有11个字段,而hive中只有10个字段,很明显需要同步数据的两个表的字段数不一致!
但问题可没有简单!
在反复确认业务需求的字段数为10个,我就开始纳闷了为啥异常中总说Hbase中有11个字段?
后来查了多方资料后终于得出了答案:
在创建hive/hbase相关联的表时,hbase表结构默认会有一个字段key,如果没有一个显示的字段’key’那么在创建表的进修,会自己创建,这样hive对应的表就会出现问题,所以在hive对应的表里一定要加上key这个字段,为了避免这个问题,在hbase表结构里可以显示的添加’key’字段,这样不容易出问题。
所以我们在创建的hive表中再加一个string 类型的 key
就好了٩(๑❛ᴗ❛๑)۶