您好,登錄后才能下訂單哦!
本篇內容介紹了“Oracle存儲過程Procedure分析”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
我們都知道即便是寫得最好的PL/SQL程序也會遇到錯誤或未預料到的事件。一個優秀的程序都應該能夠正確處理各種出錯情況,并盡可能從錯誤中恢復。
任何ORACLE錯誤(報告為ORA-xxxxx形式的Oracle錯誤號)、PL/SQL運行錯誤或用戶定義條件,PL/SQL編譯錯誤不能通過PL/SQL異常處理來處理,因為這些錯誤發生在PL/SQL程序執行之前。
ORACLE 提供異常情況(EXCEPTION)和異常處理(EXCEPTION HANDLER)來實現錯誤處理。
異常情況處理(EXCEPTION)是用來處理正常執行過程中未預料的事件,程序塊的異常處理預定義的錯誤和自定義錯誤,由于PL/SQL程序塊一旦產生異常而沒有指出如何處理時,程序就會自動終止整個程序運行。
有三種類型的異常錯誤:
1、預定義 ( Predefined )錯誤
ORACLE預定義的異常情況大約有24個。對這種異常情況的處理,無需在程序中定義,由ORACLE自動將其引發。
2、非預定義 ( Predefined )錯誤
即其他標準的ORACLE錯誤。對這種異常情況的處理,需要用戶在程序中定義,然后由ORACLE自動將其引發。
3、用戶定義(User_define) 錯誤
程序執行過程中,出現編程人員認為的非正常情況。對這種異常情況的處理,需要用戶在程序中定義,然后顯式地在程序中將其引發。
異常處理部分一般放在 PL/SQL 程序體的后半部,結構為:
EXCEPTION
WHEN first_exception THEN
WHEN second_exception THEN
WHEN OTHERS THEN
END;
異常處理可以按任意次序排列,但 OTHERS 必須放在最后。
舉個例子
create or replace procedure emp_exce_p(empno number) is
v_sal emp.sal%type;
begin
select sal into v_sal from emp where empno = empno;
if v_sal <= 1500
then
update emp set sal = sal + 100 where empno = empno;
dbms_output.put_line('empno: ' || empno || ' sal update!');
else
dbms_output.put_line('empno: ' || empno || ' sal is already to high!');
end if;
exception
when no_data_found
then dbms_output.put_line('empno: ' || empno || ' not found!');
when too_many_rows
then dbms_output.put_line('there hav too manay rows');
when others
then dbms_output.put_line(sqlcode || '---' || sqlerrm);
end;
/
其中
No_data_found 表示 SELECT INTO沒有找到數據
Too_many_rows 表示 SELECT INTO 返回多行
“Oracle存儲過程Procedure分析”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。