oracle 未找到方案,Oracle常见错误:ORA-01403 的根本原因和解决方案

Oracle常见错误:ORA-01403 ORA-06512: 在 "MALL.PUB_YANG_logoN_ORGAN",line 88 ORA-06512: 在 line 1 at com.yangcq.flow.processflow.ProcessflowFunction.execute(ProcessflowFunction.java:102) at com.opensymphony.workflow.AbstractWorkflow.executeFunction(AbstractWorkflow.java:869) at com.opensymphony.workflow.AbstractWorkflow.transitionWorkflow(AbstractWorkflow.java:1042) at com.opensymphony.workflow.AbstractWorkflow.doAction(AbstractWorkflow.java:567) at com.yangcq.flow.processflow.BaseProcessflow.executeProcessflow(BaseProcessflow.java:65) at com.yangcq.flow.processflow.BaseProcessflow.executeProcessflow(BaseProcessflow.java:39) at com.yangcq.web.spring.DefaultFlowExecuteHandler.executeProcessflow(DefaultFlowExecuteHandler.java:58) at com.yangcq.service.ProcessflowExecuteService.execute(ProcessflowExecuteService.java:164) at com.yangcq.flow.processflow.function.ProcessflowExecFunction.exec(ProcessflowExecFunction.java:33) ... 48 more Caused by: com.yangcq.Exception: root cause: sqlMapClient operation; sql []; --- The error occurred in config/sqlmap/public.xml. --- The error occurred while applying a parameter map. --- Check the public.pwdErrorOperate. --- Check the statement (update procedure Failed). --- Cause: java.sql.sqlException: ORA-01403: 未找到任何数据 88行的sql是这样的(为了便于阅读,我把这行代码进行了格式化,多行显示): SELECT LCL_LASTFAIL,LCL_FAILTODAY INTO V_LASTDATE,V_FAILCOUNT FROM CB_logoN_CTRL WHERE LCL_BRANCHID = IN_BRANCHID AND LCL_USERID = IN_CSTNO||IN_USERID; 根本原因:SELECT语句查询出来的结果为空,此时把查询出来的空值赋给2个变量,就出现了上面这个错误。ORA-01403: 未找到任何数据,报这个错误 通常都是SELECT INTO 语句查询结果为空的原因。这个报错是我们在使用PL/sql进行调试时,经常遇到的一个问题。 解决方案:查看一下是不是数据的问题,导致查询结果为空。 如果我们使用Oracle的异常处理机制来捕获这个异常的话,控制台就不会打印错误信息了。 Oracle异常处理机制 为了开发和维护的方便,Oracle定义了常见的异常,主要有以下几个: 1,DUP_VAL_ON_INDEX 异常码 ORA-00001 试图向唯一索引列插入重复值 2,INVALID_CURSOR 异常码 ORA-01001 试图进行非法游标操作 3,INVALID_NUMBER 异常码 ORA-01722 试图将字符串转化成数字 4,NO_DATA_FOUND 异常码 ORA-01403 SELECT INTO 语句中没有任何返回结果 5,TOO_MANY_ROWS 异常码 ORA-01422 SELECT INTO 语句中返回结果 6,ZERO_DIVIDE 异常码 ORA-01476 试图用0作为除数 7,CURSOR_ALREADY_OPEN 异常码 ORA-06511 试图打开一个已经打开的游标 PL/sql中用EXCEPTION关键字来作为异常的开始标志。一旦一个存储过程发生异常,就会执行异常语句之后的sql。 扩展阅读:Oracle中的ROWNUM关键字 在查询的结果集中,ROWNUM关键字为结果集中的每一行标识一个行号,第一行返回1,第二行返回2...,以此类推。通过ROWNUM关键字,我们可以控制查询的记录数。如下: SELECT * FROM ENT_ROLE WHERE ROWNUM < 10; --查询ENT_ROLE中的前9条记录 ROWNUM与ROWID的区别:ROWID是插入记录时生成的,标识的是行的物理地址;ROWNUM是查询数据时生成的,标识的是查询结果中行的顺序。 关于ROWNUM还有一点需要说明的就是,下面的写法,不返回任何查询结果: SELECT * FROM ENT_ROLE WHERE ROWNUM > 10; SELECT * FROM ENT_ROLE WHERE ROWNUM >= 10; 那么Oracle如何实现分页呢? --Oracle分页查询 SELECT * FROM ( SELECT ROWNUM R,YANGCQ_ID,YANGCQ_BRANCHID FROM YANGCQ_USER WHERE ROWNUM <= 10 ) WHERE R > 5; 流程解析:第一步内部查询得到ROWNUM,并且起个别名R;然后外部查询使用的R列,其实是内层查询的一个列,而不是行的标号了。 同样的,也可以采用类似的方法: SELECT * FROM ( SELECT ROWNUM R,YANGCQ_BRANCHID FROM YANGCQ_USER ) WHERE R > 5 AND R <= 10;

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值