insert into时(string->bigint)自动类型转换

本文探讨了Hive中从string类型转换为bigint类型的自动转换过程,并详细分析了一个具体案例,其中涉及到UDFToLong函数如何处理无法转换的string值。文章还讨论了异常处理方式及其背后的逻辑。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

原表src:

hive> desc src;
OK
key	string	
value	string	
Time taken: 0.148 seconds
hive> select * from src;
OK
238	val_238
Time taken: 0.107 seconds

建一个新的表create table src111(key bigint, value bigint); 
insert数据到src111表中 insert into table src111 select * from src; 
src的两个字段都是string,src111的两个表都是bigint,hive会做自动转换,通过UDFToLong这个udf自动把string转换成bigint,但是value值val_238无法转换成long 所以src111的值是:

hive> select * from src111;                              
OK
238	0
Time taken: 0.107 seconds

UDFToLong在做类型转换时,如果string无法转换成long会得到NumberFormatException异常,但是这个异常没有被抛出。。。

} catch (NumberFormatException e) {
   // MySQL returns 0 if the string is not a well-formed numeric value.
   // return LongWritable.valueOf(0);
   // But we decided to return NULL instead, which is more conservative.
   return null;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值