oracle 異常處理 exception

taogchan發表於2011-11-23
在實際開發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保持一直,這樣可以捕獲異常,做相關操作。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/22392018/viewspace-711833/,如需轉載,請註明出處,否則將追究法律責任。

相關文章