在使用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,希望对你们有帮助