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()函数的区别

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值