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

    如果有人知道的还请指教

  • 相关阅读:
    kuberdm安装
    docker网络
    docker安装及基本使用
    慢日志
    mysql-5.7主从复制
    MySQL-5.6主从复制
    MySQL索引原理
    Kubernetes的kubeadm项目安装部署
    十六、kubernetes之安全实验案例
    十五、Kubernetes之安全配置
  • 原文地址:https://www.cnblogs.com/zhouyeqin/p/6438834.html
Copyright © 2011-2022 走看看