mysql bigint转string_insert into时(string->bigint)自动类型转换 - bupt04406 - ITeye博客

原表src:

hive> desc src;

OK

keystring

valuestring

Time taken: 0.148 seconds

hive> select * from src;

OK

238val_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

2380

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;

}

分享到:

18e900b8666ce6f233d25ec02f95ee59.png

72dd548719f0ace4d5f9bca64e1d7715.png

2012-06-14 12:30

浏览 8031

评论


版权声明:本文为weixin_39947016原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。