Oracle中判断一个字符串是否为全数字详解数据库

在一个字段上使用sum()聚合函数的时候报“ORA-01722:无效数字”错误,原因是该字段值有非数字

其中一个解决方法是将只要包含非数字的都替换为0

select sum(to_number(nvl2(translate(LA_J_B, '/1234567890.', '/'), '0', LA_J_B))) as LA_J_B 
from BUS_BB_RLXHL

这里使用到了两个关键函数,一个是translate函数

translate(expr, from_strimg, to_string)

返回expr,其中from_string中的每个字符的所有出现都被to_string中的相应字符替换。具体参考Oracle中的translate函数用法

另一个是nvl2函数

nvl2(expr1, expr2, expr3)

如果expr1不为空,则nvl2返回expr2。如果expr1为空,则nvl2返回expr3。具体参考Oracle中nvl(), nvl2()函数的区别

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/4118.html

(0)
上一篇 2021年7月16日
下一篇 2021年7月16日

相关推荐

发表回复

登录后才能评论