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

    如果有人知道的还请指教

  • 相关阅读:
    第一章 快速入门
    增量式PID控制算法
    第二章 变量和基本类型
    位置式PID和增量式PID区别?
    I2C
    Linux系统进程调用列表
    Linux下I/O模型
    Linux下多路复用接口
    新浪博客网页编辑器PHP版带有上传图片功能
    晕死!博客园把我搞晕了!
  • 原文地址:https://www.cnblogs.com/zhouyeqin/p/6438834.html
Copyright © 2011-2022 走看看