zoukankan      html  css  js  c++  java
  • plsql里面执行正常,java运行报ORA-01722: 无效数字

    贴代码:

    <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复制到数据库执行的时候不管条件是如何顺序都是可以的

    如果有人知道的还请指教

  • 相关阅读:
    KMP算法小结
    算法二叉搜索树之AVL树
    算法导论之红黑树的学习
    算法导论小结(一)
    感悟或摘抄
    js中神奇的东西
    简单了解webservice
    用<![CDATA[]]>将xml转义为 纯文本
    简单了解soap协议
    java写webservice接口
  • 原文地址:https://www.cnblogs.com/zhouyeqin/p/6438834.html
Copyright © 2011-2022 走看看