永发信息网

数据库中bigint怎么转换为string

答案:1  悬赏:80  手机版
解决时间 2021-02-23 18:11
  • 提问者网友:沦陷
  • 2021-02-23 12:54
数据库中bigint怎么转换为string
最佳答案
  • 五星知识达人网友:鱼忧
  • 2021-02-23 13:42
原表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;
}
【TSD。M】
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯