Impala解决cast导致UDF ERROR: Decimal expression overflowed

在使用cast as decimal时,有时会发生报错,报错内容大致为:

[ImpalaJDBCDriver](500312) Error in fetching data rows: UDF ERROR: Decimal expression overflowed

看过一篇也是该报错的,但是他没法给出解决方案;在这里我们说明一下如果发生以上报错,我们的具体解决方式是什么。

上述报错大致理解为:UDF错误:十进制表达式溢出

注意这里报错不是BUG,而是数据有问题,NaN;有兴趣了解原因的小伙伴们,可以把你的 decimal(m,n) 改成 float ,你就会发现,该字段有的结果是NaN

不出意外的话,你们跟我一样也是在做除法运算;那么你们就知道了报错原因了:NaN的出现一般都是因为算法违背规则导致,除法运算中,除数(分母)不能位0,如果有某条数据中除数是0,那么就会导致上述报错,而使我们的impala sql 不能正常运行

那么解决这个问题的方式就有啦,那就是做除法运算之前,做一下判断,如果除数为0,则不做运算直接为0;

比如我的场景下,就将sql 调整为:

select cast(if(cnt=0,0,bonus/cnt) as decimal(4,2)) v from tablename

以上,就可以解决在impala查询中,使用decimal时,导致的上述报错UDF ERROR: Decimal expression overflowed,希望对你们有帮助

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值