亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

Oracle存儲過程Procedure分析

發布時間:2021-11-11 16:54:45 來源:億速云 閱讀:172 作者:iii 欄目:關系型數據庫

本篇內容介紹了“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分析”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

弋阳县| 邯郸县| 红安县| 诏安县| 合水县| 当涂县| 临颍县| 宣恩县| 长泰县| 五原县| 襄垣县| 礼泉县| 衡山县| 瓦房店市| 芒康县| 黎平县| 中牟县| 贵溪市| 黔西| 义马市| 治多县| 新野县| 黄龙县| 南康市| 灌阳县| 白河县| 通榆县| 岳池县| 西安市| 高雄市| 酉阳| 文化| 林西县| 永嘉县| 安新县| 望江县| 大悟县| 海林市| 柳河县| 海晏县| 马尔康县|