




下載本文檔
版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
PL/SQL子程序簡介Oracle系列之五目標創建和使用子程序子程序2-1命名的PL/SQL塊,編譯并存儲在數據庫中。子程序的各個部分:聲明部分可執行部分子程序的分類:過程-執行某些操作函數-執行操作并返回值子程序2-2子程序的優點:模塊化將程序分解為邏輯模塊可重用性可以被任意數目的程序調用可維護性簡化維護操作安全性通過設置權限,使數據更安全過程8-1過程是用于完成特定任務的子程序
例如:前往售票廳詢問關于車票的信息排隊等候在柜臺購買車票過程8-2創建過程的語法:CREATE[ORREPLACE]PROCEDURE<procedurename>[(<parameterlist>)]IS|AS<localvariabledeclaration>BEGIN<executablestatements>[EXCEPTION<exceptionhandlers>]END;創建過程,可指定運行過程需傳遞的參數處理異常包括在過程中要執行的語句過程8-3CREATEORREPLACEPROCEDUREfind_emp(emp_noNUMBER)ASempnameVARCHAR2(20);BEGINSELECTenameINTOempnameFROMEMPWHEREempno=emp_no;DBMS_OUTPUT.PUT_LINE('雇員姓名是'||empname);EXCEPTIONWHENNO_DATA_FOUNDTHENDBMS_OUTPUT.PUT_LINE('雇員編號未找到');ENDfind_emp;/過程8-4過程參數的三種模式:IN用于接受調用程序的值默認的參數模式OUT用于向調用程序返回值INOUT用于接受調用程序的值,并向調用程序返回更新的值過程8-5SQL>CREATEORREPLACEPROCEDUREitemdesc(item_codeINVARCHAR2)ISv_itemdescVARCHAR2(5);BEGINSELECTitemdescINTOv_itemdescFROMitemfileWHEREitemcode=item_code;DBMS_OUTPUT.PUT_LINE(item_code||'項目的說明為'||v_itemdesc);END;/SQL>SETSERVEROUTPUTONSQL>EXECUTEitemdesc('i201');執行過程的語法:
EXECUTEprocedure_name(parameters_list);過程8-6SQL>CREATEORREPLACEPROCEDUREtest(value1INVARCHAR2,value2OUTNUMBER)ISidentityNUMBER;BEGINSELECTITEMRATEINTOidentityFROMitemFileWHEREitemcode=value1;IFidentity<200THENvalue2:=100;ENDIF;END;DECLAREvalue1VARCHAR2(5):='i202';value2NUMBER;BEGINtest(value1,value2);DBMS_OUTPUT.PUT_LINE('value2的值為'||TO_CHAR(value2));END;/過程8-7CREATEORREPLACEPROCEDUREswap(p1INOUTNUMBER,p2INOUTNUMBER)ISv_tempNUMBER;BEGINv_temp:=p1;p1:=p2;p2:=v_temp;END;/SQL>SETSERVEROUTONSQL>DECLAREnum1NUMBER:=100;num2NUMBER:=200;BEGINswap(num1,num2);DBMS_OUTPUT.PUT_LINE('num1='||num1);DBMS_OUTPUT.PUT_LINE('num2='||num2);END;/過程8-8將過程的執行權限授予其他用戶:刪除過程:SQL>GRANTEXECUTEONfind_empTOMARTIN;SQL>GRANTEXECUTEONswapTOPUBLIC;SQL>DROPPROCEDUREfind_emp;函數4-1函數是可以返回值的命名的PL/SQL子程序。
創建函數的語法:
CREATE[ORREPLACE]FUNCTION
<functionname>[(param1,param2)]RETURN<datatype>IS|AS[localdeclarations]BEGINExecutableStatements;RETURNresult;EXCEPTIONExceptionhandlers;END;函數4-2定義函數的限制:函數只能接受IN參數,而不能接受INOUT或OUT參數形參不能是PL/SQL類型函數的返回類型也必須是數據庫類型訪問函數的兩種方式:使用PL/SQL塊使用SQL語句函數4-3創建函數:從SQL語句調用函數:CREATEORREPLACEFUNCTIONfun_helloRETURNVARCHAR2ISBEGINRETURN'朋友,您好';END;/SQL>SELECTfun_helloFROMDUAL;函數4-4CREATEORREPLACEFUNCTIONitem_price_range(priceNUMBER)RETURNVARCHAR2ASmin_priceNUMBER;max_priceNUMBER;BEGINSELECTMAX(ITEMRATE),MIN(ITEMRATE)INTOmax_price,min_priceFROMitemfile;IFprice>=min_priceANDprice<=max_priceTHENRETURN'輸入的單價介于最低價與最高價之間';ELSERETURN'超出范圍';ENDIF;END;/DECLAREPNUMBER:=300;MSGVARCHAR2(200);BEGINMSG:=item_price_range(300);DBMS_OUTPUT.PUT_LINE(MSG);END;/過程和函數的比較過程函數作為PL/SQL語句執行作為表達式的一部分調用在規格說明中不包含RETURN子句必須在規格說明中包含RETURN子句不返回任何值必須返回單個值可以包含RETURN語句,但是與函數不同,它不能用于返回值必須包含至少一條RETURN
語句Java中如何調用子程序Java中對于自定義函數的處理和系統提供的沒有不同調用過程的方法使用CallableStatement對象使用
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 快樂運動會的主題話題話題類作文4篇
- 醫藥流通行業供應鏈優化與成本控制智能供應鏈管理供應鏈管理倉儲管理優化報告001
- 旅游行業戶外探險活動安全須知合同
- 學前教育信息化師資培訓與能力提升策略分析報告001
- 護理查房形式
- 資源型城市綠色轉型中的綠色產業與數字經濟融合發展報告
- 地熱能供暖區域項目市場潛力與2025年技術創新研究報告
- 建筑信息模型(BIM)技術在2025年項目管理中的創新應用研究報告
- 2025年眼科醫療器械技術進步與市場潛力發展研究報告
- 2025-2030中國餐飲收銀一體機行業需求規模與投資前景預測報告
- 2023年護理考試-外科護理(副高)歷年考試真題試卷摘選答案
- 2022年廣東高考成績一分一段表重磅出爐
- 新版病人搬運(輪椅)操作評分標準
- 重癥監護ICU護理實習生出科考試試題及答案
- GB/Z 22074-2008塑料外殼式斷路器可靠性試驗方法
- GB/T 32360-2015超濾膜測試方法
- GB/T 15558.1-2015燃氣用埋地聚乙烯(PE)管道系統第1部分:管材
- 中藥學全套(完整版)課件
- 工程施工停止點檢查表
- 國開專科《外國文學》十年期末考試題庫及答案
- 《滅火器維修》GA95-2015(全文)
評論
0/150
提交評論