ORA-01722无效数字错误解决记录

      今天使用Oracle查询时候遇到了ORA01722错误:无效数字

    
ORA-01722无效数字错误解决记录
 

      一看错误就是数据类型不匹配造成的,我的查询字段key_1虽然是varchar2类型的,但里面放的是number数字,查看aa表type_1字段里面值是没有非数字(数字类型)。我的查询语句如下:

    

select nvl((select value_1
             from static_mapp_table
            where key_1 = aa.type_1
              and key_type = 'TEST'),
           '未知')
 from aa

     简单的说static_mapp_table是一个类似Map的表,里面有key,value根据类型一一对应。
aa表的type_1字段确认不可能出问题,查看static_mapp_table表里面key_1字段都是数字,
而是直接使用:

    

select * from static_mapp_table where key_1='10000018' and key_type='TEST'

    查询,查询结果居然是NULL,而是怀疑该字段里面有非数字类型存在,直接使用

    

select value_1,length(value_1)
  from static_mapp_table
 where 1 = 1
   and key_type = 'TEST'

    结果如下

   
ORA-01722无效数字错误解决记录
     如上所示,该字段初看长度是8实际长度是9,很可能里面多了空格

    

     解决方法:把空格去掉

     全文完    

你可能感兴趣的:(oracle)