日期:2014-05-16  浏览次数:20512 次

oracle 异常处理 exception

在实际开发plsql中,我们常常会将异常的信息保留到日记表中,以备以后检查时使用,这样我们就可以使用sqlcode 和sqlerm 函数来记录异常和区分异常。但是要注意:sqlcode和sqlerrm不可以直接在sql语句中使用,必须将它赋值给一个局部变量。
?
create?table?err_log(name varchar2(100),err_code number(10),err_message
varchar2(100),occur_date date);
--no_data_found和too_many_rows是经常发生的异常,所以对于plsql写这样的异常捕获是很好的
--系统预定义异常
declare
a testerr%rowtype;--define a variable
--define error message
v_err_code err_log.err_code%type;
v_err_message err_log.err_message%type;
vname err_log.name%type;
begin
select * into a from testerr where name='test';
--start trap exception
exception
when others then
--必须要将sqlcode和sqlerr赋值给变量,不可以直接在sql语句中使用
vname:='select * into a from testerr where name=''test''; this statement,a type
is testerr%rowtype';
v_err_code:=sqlcode;
v_err_message:=sqlerrm;
insert into err_log values(vname,v_err_code,v_err_message,sysdate);
end;
/
?
自定义异常:
Error_number:用户指定的异常数字,范围是-20000 到-20999。
Message:用户指定的异常信息,字符最大长度为2048 个字节。
True|false:可选参数,true表示放到先前异常的stack中,默认为false,替换先前的所
有异常。
例子:
/**
raise_application_error
**/
declare
--define user-define exception
invalidate_classes_err exception;
pragma exception_init(invalidate_classes_err,-20029);
--start execute field
begin
update classes set name='aa'where id=10000;<