plsql異常錯(cuò)誤處理_第1頁(yè)
plsql異常錯(cuò)誤處理_第2頁(yè)
plsql異常錯(cuò)誤處理_第3頁(yè)
plsql異常錯(cuò)誤處理_第4頁(yè)
plsql異常錯(cuò)誤處理_第5頁(yè)
已閱讀5頁(yè),還剩12頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、異常錯(cuò)誤處理 異常處理概念 異常情況處理(EXCEPTION)是用來(lái)處理正常執(zhí)行過(guò)程中未預(yù)料的事件,程序塊的異常處理預(yù)定義的錯(cuò)誤和自定義錯(cuò)誤,由于PL/SQL程序塊一旦產(chǎn)生異常而沒(méi)有指出如何處理時(shí),程序就會(huì)自動(dòng)終止整個(gè)程序運(yùn)行 有三種類型的異常錯(cuò)誤 :預(yù)定義 ( Predefined )錯(cuò)誤ORACLE預(yù)定義的異常情況大約有24個(gè)。對(duì)這種異常情況的處理,無(wú)需在程序中定義,由ORACLE自動(dòng)將其引發(fā)。 非預(yù)定義 ( Predefined )錯(cuò)誤 即其他標(biāo)準(zhǔn)的ORACLE錯(cuò)誤。對(duì)這種異常情況的處理,需要用戶在程序中定義,然后由ORACLE自動(dòng)將其引發(fā)。 異常處理概念 有三種類型的異常錯(cuò)誤 :用戶定

2、義(User_define) 錯(cuò)誤程序執(zhí)行過(guò)程中,出現(xiàn)編程人員認(rèn)為的非正常情況。對(duì)這種異常情況的處理,需要用戶在程序中定義,然后顯式地在程序中將其引發(fā)。 異常處理異常處理部分一般放在 PL/SQL 程序體的后半部,結(jié)構(gòu)為 :EXCEPTION WHEN first_exception THEN WHEN second_exception THEN WHEN OTHERS THEN END; 異常處理可以按任意次序排列,但 OTHERS 必須放在最后 預(yù)定義的異常處理 錯(cuò)誤號(hào) 異常錯(cuò)誤信息名稱 說(shuō)明 ORA-0001 Dup_val_on_index 試圖破壞一個(gè)唯一性限制 ORA-0051Ti

3、meout_on_resource 在等待資源時(shí)發(fā)生超時(shí) ORA-0061 Transaction_backed_out 由于發(fā)生死鎖事務(wù)被撤消 ORA-1001 Invalid_CURSOR 試圖使用一個(gè)無(wú)效的游標(biāo) ORA-1012 Not_logged_on 沒(méi)有連接到ORACLE ORA-1017 Login_denied 無(wú)效的用戶名/口令 ORA-1403 No_data_foundSELECT INTO沒(méi)有找到數(shù)據(jù) ORA-1422 Too_many_rows SELECT INTO 返回多行 ORA-1476Zero_divide 試圖被零除 ORA-1722Invalid_NU

4、MBER 轉(zhuǎn)換一個(gè)數(shù)字失敗 預(yù)定義的異常處理 錯(cuò)誤號(hào) 異常錯(cuò)誤信息名稱 說(shuō)明 ORA-6500 Storage_error 內(nèi)存不夠引發(fā)的內(nèi)部錯(cuò)誤ORA-6501 Program_error 內(nèi)部錯(cuò)誤 ORA-6502 Value_error轉(zhuǎn)換或截?cái)噱e(cuò)誤 ORA-6504 Rowtype_mismatch 縮主游標(biāo)變量與 PL/SQL變量有不兼容行類型 ORA-6511 CURSOR_already_OPEN 試圖打開(kāi)一個(gè)已存在的游標(biāo) ORA-6530 Access_INTO_null 試圖為null 對(duì)象的屬性賦值 ORA-6531 Collection_is_null 試圖將Exists

5、 以外的集合( collection)方法應(yīng)用于一個(gè)null pl/sql 表上或varray上 ORA-6532 Subscript_outside_limit 對(duì)嵌套或varray索引得引用超出聲明范圍以外 ORA-6533 Subscript_beyond_count 對(duì)嵌套或varray 索引得引用大于集合中元素的個(gè)數(shù) 異常處理對(duì)于預(yù)定義異常情況的處理,只需在PL/SQL塊的異常處理部分,直接引用相應(yīng)的異常情況名,并對(duì)其完成相應(yīng)的異常錯(cuò)誤處理即可。 例:更新指定員工工資,如工資小于1500,則加100 DECLARE v_empno emp.empno%TYPE :=7900; v_s

6、al emp.sal%TYPE;BEGIN SELECT sal INTO v_sal FROM emp WHERE empno=v_empno; IF v_sal=1500 THEN UPDATE emp SET sal=sal+100 WHERE empno=v_empno; DBMS_OUTPUT.PUT_LINE(編碼為|v_empno|員工工資已更新!); ELSE DBMS_OUTPUT.PUT_LINE(編碼為|v_empno|員工工資已經(jīng)超過(guò)規(guī)定值!); END IF; 異常處理EXCEPTION WHEN NO_DATA_FOUND THEN DBMS_OUTPUT.PUT_

7、LINE(數(shù)據(jù)庫(kù)中沒(méi)有編碼為|v_empno|的員工); WHEN TOO_MANY_ROWS THEN DBMS_OUTPUT.PUT_LINE(程序運(yùn)行錯(cuò)誤!請(qǐng)使用游標(biāo)); WHEN OTHERS THEN DBMS_OUTPUT.PUT_LINE(SQLCODE|-|SQLERRM);END; 非預(yù)定義的異常處理 對(duì)于這類異常情況的處理,首先必須對(duì)非定義的ORACLE錯(cuò)誤進(jìn)行定義 步驟如下:在PL/SQL 塊的聲明部分定義異常情況: EXCEPTION; 將其定義好的異常情況,與標(biāo)準(zhǔn)的ORACLE錯(cuò)誤聯(lián)系起來(lái),使用EXCEPTION_INIT語(yǔ)句 PRAGMA EXCEPTION_INI

8、T(, ); 在PL/SQL 塊的異常情況處理部分對(duì)異常情況做出相應(yīng)的處理。 非預(yù)定義的異常處理 例:刪除指定部門的記錄信息,以確保該部門沒(méi)有員工。 DECLARE v_deptno dept.deptno%TYPE :=&deptno; deptno_remaining EXCEPTION; PRAGMA EXCEPTION_INIT(deptno_remaining, -2292); /* -2292 是違反一致性約束的錯(cuò)誤代碼 */BEGIN DELETE FROM dept WHERE deptno=v_deptno;EXCEPTION WHEN deptno_remaining TH

9、EN DBMS_OUTPUT.PUT_LINE(違反數(shù)據(jù)完整性約束!); WHEN OTHERS THEN DBMS_OUTPUT.PUT_LINE(SQLCODE|-|SQLERRM);END; 用戶自定義的異常處理 當(dāng)與一個(gè)異常錯(cuò)誤相關(guān)的錯(cuò)誤出現(xiàn)時(shí),就會(huì)隱含觸發(fā)該異常錯(cuò)誤。用戶定義的異常錯(cuò)誤是通過(guò)顯式使用 RAISE 語(yǔ)句來(lái)觸發(fā)。當(dāng)引發(fā)一個(gè)異常錯(cuò)誤時(shí),控制就轉(zhuǎn)向到 EXCEPTION塊異常錯(cuò)誤部分,執(zhí)行錯(cuò)誤處理代碼。 對(duì)于這類異常情況的處理,步驟如下 :在PL/SQL 塊的聲明部分定義異常情況 : EXCEPTION; RAISE 在PL/SQL 塊的異常情況處理部分對(duì)異常情況做出相應(yīng)的處

10、理。 用戶自定義的異常處理例:DECLARE v_empno emp.empno%TYPE :=&empno; no_result EXCEPTION;BEGIN UPDATE emp SET sal=sal+100 WHERE empno=v_empno; IF SQL%NOTFOUND THEN RAISE no_result; END IF;EXCEPTION WHEN no_result THEN DBMS_OUTPUT.PUT_LINE(你的數(shù)據(jù)更新語(yǔ)句失敗了!); WHEN OTHERS THEN DBMS_OUTPUT.PUT_LINE(SQLCODE|-|SQLERRM);EN

11、D; RAISE_APPLICATION_ERROR函數(shù)例:declare v_deptid departments.department_id%type := &no; v_dname departments.department_name%type;begin select department_name into v_dname from departments where department_id = v_deptid; dbms_output.put_line(v_dname);exception when others then raise_application_error(-

12、20001 , department |v_deptid| does not exists);end;異常處理注意:某給定異常最多由異常處理部分的一個(gè)處理器進(jìn)行處理。如果有多個(gè)異常處理器,則PL/SQL編譯器產(chǎn)生PLS-00483錯(cuò)誤。SQLCODE返回當(dāng)前錯(cuò)誤代碼,SQLERRM返回當(dāng)前錯(cuò)誤的消息文本。對(duì)于用戶自定義異常SQLCODE返回值為1,SQLERRM返回值為User-defined ExceptionOracle錯(cuò)誤信息的最大長(zhǎng)度是512字節(jié)SQLCODE和SQLERRM的值先賦給本地變量,不能直接用于SQL語(yǔ)句異常錯(cuò)誤傳播由于異常錯(cuò)誤可以在聲明部分和執(zhí)行部分以及異常錯(cuò)誤部分出現(xiàn),

13、因而在不同部分引發(fā)的異常錯(cuò)誤也不一樣。 可執(zhí)行部分產(chǎn)生的異常: 當(dāng)一個(gè)異常錯(cuò)誤在執(zhí)行部分引發(fā)時(shí),有下列情況:1. 如果當(dāng)前塊對(duì)該異常錯(cuò)誤設(shè)置了處理,則執(zhí)行它并成功完成該塊的執(zhí)行,然后控制轉(zhuǎn)給包含塊。 2.如果沒(méi)有對(duì)當(dāng)前塊異常錯(cuò)誤設(shè)置定義處理器,則通過(guò)在包含塊中引發(fā)它來(lái)傳播異常錯(cuò)誤。然后對(duì)該包含塊執(zhí)行步驟1)。 異常錯(cuò)誤傳播聲明部分產(chǎn)生的異常: 如果在聲明部分引起異常情況,即在聲明部分出現(xiàn)錯(cuò)誤,那么該錯(cuò)誤就能影響到其它的塊 例:DECLAREAbc number(3):=abc;其它語(yǔ)句BEGIN其它語(yǔ)句EXCEPTIONWHEN OTHERS THEN 其它語(yǔ)句END; 由于Abc number(3)=abc; 出錯(cuò),盡管在EXCEPTION中說(shuō)明了WHEN

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論