在实际开发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;
--raise exception
if sql%notfound then
raise_application_error(-20029,'invalidate id=10000!');
end if;
commit;
--start trap exception
exception
when invalidate_classes_err then
dbms_output.put_line('no such id is 10000.'||sqlcode||':'||sqlerrm);
end;
这里使用了非预定义的异常,sqlcode 和sqlerrm 和raise_applicatition_error 的number 和
message保持一直,这样可以捕获异常,做相关操作。