




版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、1第9章 PL/SQL基礎(chǔ)2本章內(nèi)容熟練掌握條件選擇語(yǔ)句的使用熟練掌握循環(huán)語(yǔ)句的使用理解并掌握游標(biāo)掌握異常的處理39.2 條件選擇語(yǔ)句 選擇結(jié)構(gòu)IF條件語(yǔ)句CASE表達(dá)式4IF條件語(yǔ)句IF語(yǔ)句三種形式IF-THENIF-THEN-ELSE IF-THEN-ELSIFIF condition1 THEN statements1;ELSIF condition2 THEN statements2;, ELSE else_statements;END IF;5輸入一個(gè)員工號(hào)修改該員工的工資,如該員工為10號(hào)部門(mén),工資增加100;若為20號(hào)部門(mén),工資增加150;若為30號(hào)部門(mén),工資增加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表達(dá)式兩種形式簡(jiǎn)單CASE表達(dá)式搜索CASE表達(dá)式簡(jiǎn)單CASE表達(dá)式使用表達(dá)式確定返回值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 (沒(méi)有此成績(jī)); END CASE;END;8搜索CASE表達(dá)式使用條件確定返回值CASE WHEN condition1 THE
6、N statements1; WHEN condition2 THEN statements2; WHEN conditionn THEN statementsn; ELSE else_statements;END CASE;9根據(jù)輸入的員工號(hào)修改該員工工資。如工資低于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)基礎(chǔ)上添加循環(huán)條件,即只有滿(mǎn)足WHILE條件后才會(huì)執(zhí)行循環(huán)體中的內(nèi)容基本語(yǔ)法 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異常處理器是一個(gè)特殊的異常處理器,可以捕獲所有的異常。通常,OTHERS異常處理器總是作為異常處理部分的最后一個(gè)異常處理器,負(fù)責(zé)處理那些沒(méi)有被其他異常處理器捕獲的異常。 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í)行部分異常的傳播如果當(dāng)前語(yǔ)句塊有該異常的處理器,則執(zhí)行之,并且成功完成該語(yǔ)句塊。然后,控制權(quán)傳遞到外層語(yǔ)句塊。 如果當(dāng)前語(yǔ)句塊沒(méi)有該異常的處理器,則通過(guò)在外層語(yǔ)句塊中產(chǎn)生該異常來(lái)傳播該異常。然后,執(zhí)行對(duì)外層語(yǔ)句塊執(zhí)行步驟1。如果沒(méi)有外層語(yǔ)句塊,則該異常將傳播到調(diào)用環(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聲明部分和異常處理部分的異常立刻傳播到外層語(yǔ)句塊,即使當(dāng)前語(yǔ)句塊有異常處理器。 BEGIN DECLARE v_number NUMBER(6) :=ABC; BEGIN v_number:=10; EXCEPTION WHEN OTHERS THEN D
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 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ì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五版物業(yè)停車(chē)場(chǎng)租賃合同
- 2025年光電子器件及激光器件合作協(xié)議書(shū)
- 2025年品質(zhì)生活電器合作協(xié)議書(shū)
- 2025-2030中國(guó)酒店信息管理系統(tǒng)行業(yè)市場(chǎng)發(fā)展前瞻及投資戰(zhàn)略研究報(bào)告
- 2025-2030中國(guó)道路安全系統(tǒng)行業(yè)市場(chǎng)發(fā)展趨勢(shì)與前景展望戰(zhàn)略研究報(bào)告
- 2025-2030中國(guó)進(jìn)口食品行業(yè)市場(chǎng)發(fā)展前瞻及投資戰(zhàn)略研究報(bào)告
- 2025-2030中國(guó)運(yùn)動(dòng)鞋市場(chǎng)營(yíng)銷(xiāo)格局與前景消費(fèi)規(guī)模研究報(bào)告
- 2025-2030中國(guó)輕型客車(chē)市場(chǎng)調(diào)研及發(fā)展策略研究報(bào)告
- 2025-2030中國(guó)輪椅市場(chǎng)融資動(dòng)態(tài)及重點(diǎn)企業(yè)經(jīng)營(yíng)狀況監(jiān)測(cè)研究報(bào)告
- 2025-2030中國(guó)軌道式氧氣壓力調(diào)節(jié)器行業(yè)市場(chǎng)發(fā)展趨勢(shì)與前景展望戰(zhàn)略研究報(bào)告
- 2024年浙江省杭州市余杭區(qū)仁和街道編外招聘56人歷年高頻考題難、易錯(cuò)點(diǎn)模擬試題(共500題)附帶答案詳解
- 蘇教版五年級(jí)數(shù)學(xué)下冊(cè)第二單元測(cè)試卷附答案
- 耳部刮痧治療
- 基于STM32的智能掃地機(jī)器人設(shè)計(jì)
- 山東省青島市嶗山區(qū)育才學(xué)校2023-2024學(xué)年下學(xué)期奇點(diǎn)計(jì)劃選拔考試八年級(jí)物理試卷
- 普通生物學(xué)第17章.植物的結(jié)構(gòu)和生殖
- 獸醫(yī)檢驗(yàn)習(xí)題(附答案)
- 2024活躍用戶(hù)研究報(bào)告(小紅書(shū)平臺(tái))-千瓜-202404
- 2023年中國(guó)電動(dòng)工具行業(yè)發(fā)展白皮書(shū)
- 【歷年真題】2021年4月03512劇本寫(xiě)作自考試卷
- 河南水利與環(huán)境職業(yè)學(xué)院?jiǎn)握新殬I(yè)技能測(cè)試參考試題庫(kù)(含答案)
評(píng)論
0/150
提交評(píng)論