贴代码:
<select id="getInfo" parameterClass="java.util.HashMap" resultClass="java.util.HashMap">
<isEqual property="Type" compareValue="02">
select a.*
from INFO a
where
a.TYPE= #Type#
</isEqual>
<isEqual property="Type" compareValue="01">
select a.*
from INFO a
where
a.TYPE= #Type#
and to_number(a.END) >= to_number(#No#)
</isEqual>
</select>
当Type为01的时候报错:ORA-01722: 无效数字,,目标锁定and to_number(a.END) >= to_number(#No#)
但是将SQL复制到数据库执行的时候是可以的
问题原因:
在Type为02的时候a.END里面包含字符,Type为01的时候a.END里面只有数字
因为oracle条件是从下往上筛选的,所以to_number(a.END)在a.TYPE= #Type#之前,导致无效数字错误
处理方式:
将a.TYPE= #Type#条件放到最后
同理:筛选范围最大的条件应该放在最后面,提高执行效率
求解:
将SQL复制到数据库执行的时候不管条件是如何顺序都是可以的
如果有人知道的还请指教