sqoop导入数据到hive为空的解决办法

说下我当时遇到的情况,我在使用sqoop从mysql导入数据到hive,之前都是正常的,突然某一天发现一个字段导入到hive时为空,但是mysql是有值的,仔细观察发现这个字段类型有点特殊,特殊在哪里呢,他是tinyint(1),这种类型是比较少见的

接下来直接说解决办法:

在sqoop连接mysql的url中加上tinyInt1isBit=false,

完整的url示例:jdbc:mysql://localhost/test?tinyInt1isBit=false

解释一下加这个得含义,默认sqoop导mysql的tinyint类型时会将其转成boolean类型,而当我们的hive表这个字段为整形时,导入就会为空,加上tinyInt1isBit=false是告诉sqoop,导入的时候这种类型不要转换成boolean类型

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值