oracle異常處理明細(個人簡單總結)

2021-06-02 13:13:23 字數 3913 閱讀 5510

異常處理是針對系統中發生的各種錯誤所採取的處理措施。

pl/sql塊中的異常處理

sql**  

exception   

when first_exception then

first exception>  

when second_exception then

second exception>  

when others then

exception 

when first_exception then when second_exception then when others then

在異常處理中,用來獲取異常**和完整錯誤提示資訊的兩個子系統函式是sqlcode和sqlerrm。

對系統內部異常可通過sqlcode返回乙個oracle錯誤編碼號。sqlcode返回的編號除了「ora_01403沒發現資料」是正值之外,其他的都是負值。

sqlerrm則返回異常**相對應的錯誤資訊。對使用者定義的異常,sqlcode返回+1而且sqlerrm返回「使用者定義異常」。如果沒有異常發生,操作正常執行,則sqlcode返回0,sqlerrm返回資訊「ora_0000:正常,成功完成」。

非預定義的oracle異常

pragma exception_init(,)

在pl*sql中,pragma exception_init告訴編譯器將乙個oracle錯誤編號與異常名建立起來

sql**  

pragma exception_init的用法  

declare

e_emp_remaining exception;  

pragma exception_init(e_emp_remaining ,-2292);  

begin

delete

from dept where deptno=10;  

commit;  

exception   

when (e_emp_remaining then

dbms_output.put_line('cannot remove dept'||to_char(10)||'.employee exist.');  

end;  

pragma exception_init的用法

declare

e_emp_remaining exception;

pragma exception_init(e_emp_remaining ,-2292);

begin

delete from dept where deptno=10;

commit;

exception

when (e_emp_remaining then

dbms_output.put_line('cannot remove dept'||to_char(10)||'.employee exist.');

end;

使用者自定義異常

sql**  

declare

v_eno emp.empno%type :=&.empno;  

not_found exception;  

begin

update emp set sal=sal*1.1 where  empno=v_eno;  

if  sql% notfound then

raise not_found// 使用raise語句丟擲異常  

end if;  

exception  

when not_found then

dbms_output.put_line('you can't update the sal,the number does not!exist!');  

when others then

dbms_output.put_line('other other');  

end

declare

v_eno emp.empno%type :=&.empno;

not_found exception;

begin

update emp set sal=sal*1.1 where empno=v_eno;

if sql% notfound then

raise not_found// 使用raise語句丟擲異常

end if;

exception

when not_found then

dbms_output.put_line('you can't update the sal,the number does not!exist!');

when others then

dbms_output.put_line('other other');

end

sql**  

裡面的錯誤**和內容,都是自定義的。說明是自定義,當然就不是系統中已經命名存在的錯誤類別,是屬於一種自定義事務錯誤型別,才呼叫此函式。

error_number_in 之容許從 -20000 到 -20999 之間,這樣就不會與 oracle 的任何錯誤**發生衝突。

error_msg_in 的長度不能超過 2k,否則擷取 2k。

舉個例吧:

阻止小於18歲的使用者增加到資料庫 employee 表中

sql**  

create

or repalce trigger minimun_age_check  

before insert

on employee  

for each row  

begin

if add_months( :new.birth_date, 18*12) > sysdate  

then

end if;  

end;  

create or repalce trigger minimun_age_check

before insert on employee

for each row

begin

if add_months( :new.birth_date, 18*12) > sysdate

then

end if;

end;

在客戶端,你可以寫乙個類似下面的程式,來測試一下。

sql**  

declare

no_babies_allowed exception;  

/*將名稱與用於觸發器中的錯誤號碼關聯起來*/  

pragma exception_init(no_babies_allowed, -20001);  

begin

insert

into employee ....;  

exception  

when no_babies_allowed  

then

/*  

*/  

dbms_output.put_line(sqlerrm);  

end;  

declare

no_babies_allowed exception;

/*將名稱與用於觸發器中的錯誤號碼關聯起來*/

pragma exception_init(no_babies_allowed, -20001);

begin

insert into employee ....;

exception

when no_babies_allowed

then

/**/

dbms_output.put_line(sqlerrm);

end;

oracle異常處理明細

異常處理是針對系統中發生的各種錯誤所採取的處理措施。pl sql塊中的異常處理 sql exception when first exception then first exception when second exception then second exception when other...

ORACLE 異常處理

一 開發pl sql程式時,需要考慮到程式執行時可能出現的各種異常,當異常出現時,或是中斷程式執行,或是使程式從錯誤中恢復,從而繼續執行。常用的異常型別有 no data found 沒有發現資料 too many rows select into 語句查詢結果有多個資料行 others 可以捕捉所...

Oracle 異常處理

1 什麼是異常 在pl sql 中的乙個警告或錯誤的情形都可被稱為異常。包括編譯時錯誤 pls 和執行時錯誤 ora 乙個異常通常包含乙個錯誤 和錯誤文字,分別指示異常的編號和具體錯誤資訊。異常情況處理 exception 是用來處理正常執行過程中未預料的事件,程式塊的異常處理預定義的錯誤和自定義錯...