在一个字段上使用sum()聚合函数的时候报“ORA-01722:无效数字”错误,原因是该字段值有非数字
其中一个解决方法是将只要包含非数字的都替换为0
@H_301_4@select sum(to_number(nvl2(translate(LA_J_B,'/1234567890.','\'),'0',LA_J_B))) as LA_J_B from BUS_BB_RLXHL @H_301_4@translate(expr,from_strimg,to_string)返回expr,其中from_string中的每个字符的所有出现都被to_string中的相应字符替换。具体参考Oracle中的translate函数用法
另一个是nvl2函数
@H_301_4@nvl2(expr1,expr2,expr3)如果expr1不为空,则nvl2返回expr2。如果expr1为空,则nvl2返回expr3。具体参考Oracle中nvl(),nvl2()函数的区别
作者:itmyhome
原文链接:https://www.f2er.com/oracle/206042.html