数据库中bigint怎么转换为string

数据库中bigint怎么转换为string,第1张

原表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】

方法有多种

1:在数据库中单独存储后三位的当前值,整型类型即可。比如12,13,15等等。代码 *** 作时获取当前值+1,然后保存+1后的值,根据当前值得位数判断是否需要补零。生成如012,013,123等数据

2:使用sql语句获取id字段最大值,然后转换为字符串,截取后三位,再转为整数,然后将转后的整数+1,最后在连接上20140000就可

3:自己补充吧......

数据库日期类型是int类型的,该查询结果是datetime类型SELECT from_unixtime( `dateline` )

FROM cdb_posts如果原来类型是datetime类型,查询结果要是int类型则SELECT unix_timestamp( `dateline` )

FROM cdb_posts


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/6147254.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-16
下一篇 2023-03-16

发表评论

登录后才能评论

评论列表(0条)

保存