oracle触发器ora01403,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_ID,YANGCQ_BRANCHID

FROM

YANGCQ_USER

)

WHERE

R > 5 AND

R <= 10;

你可能感兴趣的:(oracle触发器ora01403,Oracle常见错误:ORA-01403 的根本原因和解决方案)