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

你可能感兴趣的:(Impala,sql,数据库,impala,cast,decimal)