Oracle常见错误:ORA
作者:网络转载 发布时间:[ 2016/7/28 10:49:11 ] 推荐标签:数据库 Oracle
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是查询数据时生成的,标识的是查询结果中行的顺序。
相关推荐
更新发布
功能测试和接口测试的区别
2023/3/23 14:23:39如何写好测试用例文档
2023/3/22 16:17:39常用的选择回归测试的方式有哪些?
2022/6/14 16:14:27测试流程中需要重点把关几个过程?
2021/10/18 15:37:44性能测试的七种方法
2021/9/17 15:19:29全链路压测优化思路
2021/9/14 15:42:25性能测试流程浅谈
2021/5/28 17:25:47常见的APP性能测试指标
2021/5/8 17:01:11