oracle中检查2个数字型字段合并显示后内容是否有非数字的问题

最近在oracle上碰到一个问题,一张视图,将A表中的CODE和B表中的CODE合并后作为视图C中一个字段CODE,即C.CODE=A.CODE &B.CODE,可能会出现C.CODE不是一个完整的数字型。例如:A.CODE = 1234,B.CODE = -1 那C.CODE = 1234-1,如果程序中用整形来操作会报错。

 

原本使用oracle的to_number来检查,但是发现oracle中,to_number函数如果出现的SQL语句的查询结果集中,会过滤掉不能转换为整形的数据,还是不能查出问题记录;只有to_number出现在SQL语句条件中,才会因为非数字型值而报错,不易于查询和过滤问题。

 

最后发现可以通过TRANSLATE函数来解决.

示例:TRANSLATE(A.CODE,'1234567890ABCDEFGHIJKLMNOPQRSTUVWXYZ','1234567890'),这样就能将非数字型的内容给过滤掉,实际显示的只有数字类型的值,可以避免因为异常数据造成的程序运行不能,也可以用于检查数据库中异常数据的来源

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值