溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Oracle存儲過程Procedure分析

發(fā)布時間:2021-11-11 16:54:45 來源:億速云 閱讀:161 作者:iii 欄目:關(guān)系型數(shù)據(jù)庫

本篇內(nèi)容介紹了“Oracle存儲過程Procedure分析”的有關(guān)知識,在實(shí)際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

我們都知道即便是寫得最好的PL/SQL程序也會遇到錯誤或未預(yù)料到的事件。一個優(yōu)秀的程序都應(yīng)該能夠正確處理各種出錯情況,并盡可能從錯誤中恢復(fù)。
任何ORACLE錯誤(報(bào)告為ORA-xxxxx形式的Oracle錯誤號)、PL/SQL運(yùn)行錯誤或用戶定義條件,PL/SQL編譯錯誤不能通過PL/SQL異常處理來處理,因?yàn)檫@些錯誤發(fā)生在PL/SQL程序執(zhí)行之前。
ORACLE 提供異常情況(EXCEPTION)和異常處理(EXCEPTION HANDLER)來實(shí)現(xiàn)錯誤處理。
異常情況處理(EXCEPTION)是用來處理正常執(zhí)行過程中未預(yù)料的事件,程序塊的異常處理預(yù)定義的錯誤和自定義錯誤,由于PL/SQL程序塊一旦產(chǎn)生異常而沒有指出如何處理時,程序就會自動終止整個程序運(yùn)行。
有三種類型的異常錯誤:
1、預(yù)定義 ( Predefined )錯誤
ORACLE預(yù)定義的異常情況大約有24個。對這種異常情況的處理,無需在程序中定義,由ORACLE自動將其引發(fā)。
2、非預(yù)定義 ( Predefined )錯誤
即其他標(biāo)準(zhǔn)的ORACLE錯誤。對這種異常情況的處理,需要用戶在程序中定義,然后由ORACLE自動將其引發(fā)。
3、用戶定義(User_define) 錯誤
程序執(zhí)行過程中,出現(xiàn)編程人員認(rèn)為的非正常情況。對這種異常情況的處理,需要用戶在程序中定義,然后顯式地在程序中將其引發(fā)。


異常處理部分一般放在 PL/SQL 程序體的后半部,結(jié)構(gòu)為:
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沒有找到數(shù)據(jù)
Too_many_rows 表示 SELECT INTO 返回多行

“Oracle存儲過程Procedure分析”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI