




版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、1第9章 PL/SQL基礎2本章內容熟練掌握條件選擇語句的使用熟練掌握循環(huán)語句的使用理解并掌握游標掌握異常的處理39.2 條件選擇語句 選擇結構IF條件語句CASE表達式4IF條件語句IF語句三種形式IF-THENIF-THEN-ELSE IF-THEN-ELSIFIF condition1 THEN statements1;ELSIF condition2 THEN statements2;, ELSE else_statements;END IF;5輸入一個員工號修改該員工的工資,如該員工為10號部門,工資增加100;若為20號部門,工資增加150;若為30號部門,工資增加200;否則增加
2、300。 DECLARE v_deptno emp.deptno%type; v_increment NUMBER(4); v_empno emp.empno%type;BEGIN v_empno:=&x; SELECT deptno INTO v_deptno FROM emp WHERE empno=v_empno; IF v_deptno=10 THEN v_increment:=100; ELSIF v_deptno=20 THEN v_increment:=150; ELSIF v_deptno=30 THEN v_increment:=200; ELSE v_increment:=
3、300; END IF; UPDATE emp SET sal=sal+v_increment WHERE empno=v_empno;END;6CASE表達式兩種形式簡單CASE表達式搜索CASE表達式簡單CASE表達式使用表達式確定返回值CASE search_exp WHEN exp1 THEN result1; WHEN exp2 THEN result2; WHEN expn THEN resultn; ELSE default_ result;END CASE; 7DECLARE v_deptno emp.deptno%type; v_increment NUMBER(4); v_
4、empno emp.empno%type;BEGIN v_empno:=&x; SELECT deptno INTO v_deptno FROM emp WHERE empno=v_empno; CASE v_deptno WHEN 10 THEN v_increment:=100; WHEN 20 THEN v_increment:=150; WHEN 30 THEN v_increment:=200; ELSE v_increment:=300;END CASE;UPDATE emp SET sal=sal+v_increment WHERE empno=v_empno; END; BEG
5、IN CASE &grade WHEN A THEN DBMS_OUTPUT.PUT_LINE(優(yōu)異); WHEN B THEN DBMS_OUTPUT.PUT_LINE (優(yōu)秀); WHEN C THEN DBMS_OUTPUT.PUT_LINE (良好); WHEN D THEN DBMS_OUTPUT.PUT_LINE (一般); WHEN F THEN DBMS_OUTPUT.PUT_LINE (較差); ELSE DBMS_OUTPUT.PUT_LINE (沒有此成績); END CASE;END;8搜索CASE表達式使用條件確定返回值CASE WHEN condition1 THE
6、N statements1; WHEN condition2 THEN statements2; WHEN conditionn THEN statementsn; ELSE else_statements;END CASE;9根據輸入的員工號修改該員工工資。如工資低于1000,則工資增加200;如工資在1000-2000之間,則增加150;如工資在2000-3000之間,則增加100;否則增加50。 DECLARE v_sal emp.sal%type; v_increment NUMBER(4); v_empno emp.empno%type;BEGIN v_empno:=&x; SELE
7、CT sal INTO v_sal FROM emp WHERE empno=v_empno; CASE WHEN v_sal1000 THEN v_increment:=200; WHEN v_sal2000 THEN v_increment:=150; WHEN v_sal 50; END LOOP;END; 13WHILE循環(huán)WHILE循環(huán)是在LOOP循環(huán)基礎上添加循環(huán)條件,即只有滿足WHILE條件后才會執(zhí)行循環(huán)體中的內容基本語法 WHILE condition LOOP statements;END LOOP; 14利用WHILE循環(huán)向temp_table表中插入50條記錄。DECLA
8、RE v_counter BINARY_INTEGER :=1;BEGIN WHILE v_counter 6000 THEN RAISE e_highlimit; END IF;EXCEPTION WHEN e_highlimit THEN DBMS_OUTPUT.PUT_LINE(The salary is too large!); ROLLBACK;END; 53OTHERS異常處理器OTHERS異常處理器是一個特殊的異常處理器,可以捕獲所有的異常。通常,OTHERS異常處理器總是作為異常處理部分的最后一個異常處理器,負責處理那些沒有被其他異常處理器捕獲的異常。 54DECLARE v_
9、sal emp.sal%TYPE; e_highlimit EXCEPTION;BEGIN SELECT sal INTO v_sal FROM emp WHERE ename=JOAN; UPDATE emp SET sal=sal+100 WHERE empno=7900; IF v_sal6000 THEN RAISE e_highlimit; END IF;EXCEPTION WHEN e_highlimit THEN DBMS_OUTPUT.PUT_LINE(The salary is too large!); ROLLBACK; WHEN OTHERS THEN DBMS_OUTP
10、UT.PUT_LINE(There is some wrong in selecting!);END; 55異常的傳播可執(zhí)行部分異常的傳播如果當前語句塊有該異常的處理器,則執(zhí)行之,并且成功完成該語句塊。然后,控制權傳遞到外層語句塊。 如果當前語句塊沒有該異常的處理器,則通過在外層語句塊中產生該異常來傳播該異常。然后,執(zhí)行對外層語句塊執(zhí)行步驟1。如果沒有外層語句塊,則該異常將傳播到調用環(huán)境。 56DECLARE v_sal emp.sal%TYPE;BEGIN BEGIN SELECT sal INTO v_sal FROM emp WHERE ename=JOAN; EXCEPTION WHE
11、N NO_DATA_FOUND THEN DBMS_OUTPUT.PUT_LINE(There is not such an employee!); END; DBMS_OUTPUT.PUT_LINE(Now this is outputted by outer block!);END;There is not such an employee!Now this is outputted by outer block! 57DECLARE v_sal emp.sal%TYPE;BEGIN BEGIN SELECT sal INTO v_sal FROM emp WHERE deptno=10;
12、 EXCEPTION WHEN NO_DATA_FOUND THEN DBMS_OUTPUT.PUT_LINE(There is not such an employee!); END; DBMS_OUTPUT.PUT_LINE(Now this is outputted by outer block!);EXCEPTION WHEN TOO_MANY_ROWS THEN DBMS_OUTPUT.PUT_LINE(There are more than one employee!);END;There are more than one employee!58聲明部分和異常處理部分的異常立刻傳播到外層語句塊,即使當前語句塊有異常處理器。 BEGIN DECLARE v_number NUMBER(6) :=ABC; BEGIN v_number:=10; EXCEPTION WHEN OTHERS THEN D
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 電纜裸露施工方案
- 2024-2025學年新教材高中物理 第13章 電磁感應與電磁波初步 3 電磁感應現象及應用教學設計 新人教版必修第三冊
- 氨法脫硫結果計算
- 安全隱患排查方面
- 2024-2025學年新教材高中化學 第1章 原子結構 元素周期律 第3節(jié) 第1課時 認識同周期元素性質的遞變規(guī)律教學設計 魯科版必修第二冊
- 2024馬克思主義基本原理概論自考
- 組裝木箱施工方案
- 安徽省長豐縣高中英語 Unit 20 New Frontiers Lesson 1 Futurology教學設計 北師大版選修7
- 2025年新版國際貨物買賣合同全新出爐
- 2025金杜律所合同審查要點與核心條款深度解析
- 校長在中考復習備考研討會上講話:聚焦中考命題核心!靶向突破薄弱環(huán)節(jié)
- 2025年部編版道德與法治小學三年級下冊全冊教案(含教學計劃)
- 行政復議法-形考作業(yè)1-國開(ZJ)-參考資料
- 可下載打印的公司章程
- 注塑成型試題-及答案
- 科室急救備用藥品領用補充工作流程
- GB_T 16986-2018 商品條碼 應用標識符(高清正版)
- 白內障手術知情同意書
- 關于液壓支架四連桿建模及設計
- 特種設備焊接操作人員焊績記錄表
- 完整的弱電施工組織方案[1]
評論
0/150
提交評論