您的位置:首页 > 数据库 > Oracle

oracle 连表查询时的数据类型问题

2011-08-08 11:03 357 查看
今天同事在执行以下sql时报错:ORA-01722: invalid numberORA-01722: invalid number

select a0.*

  from BK_FUNCTION a0

  join BK_USER_POWER o0 on o0.APPID = a0.ID

 where o0.DATAID = '81'

   and o0.TYPES = '2'

   and a0.VALID = '1';

尝试直接执行

select a0.*

  from BK_FUNCTION a0

  join BK_USER_POWER o0 on o0.APPID = a0.ID

 没有报错

逐条去除查询条件 发现 o0表的字段都去掉后 报错消失

尝试修改 where o0.DATAID = '81'

   and o0.TYPES = '2'



 where o0.DATAID = '81'

   and o0.TYPES = '1'

后报错消失

最终发现导致问题的原因是联合查询的On的字段类型不一致 a0.ID是number类型的 

修改字段类型后问题消失

弯路主要是在执行不同的查询条件时 有时报错 有时不报

最后结论是 在执行联合查询时 字段类型不一致时 oracle聪明的会隐式转换

这就是 select a0.*

  from BK_FUNCTION a0

  join BK_USER_POWER o0 on o0.APPID = a0.ID 为什么成功的原因

但当查询条件有结果时 oracle的智商就不足以处理这种情况了 不会去做隐式转换 

要么在查询时 加 to_number   on o0.APPID =  to_number(a0.ID)

或者 最好的方法 修改字段类型 -. -
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  oracle function join user sql
相关文章推荐