oracle學習-pl-sql子程序簡介五_第1頁
oracle學習-pl-sql子程序簡介五_第2頁
oracle學習-pl-sql子程序簡介五_第3頁
oracle學習-pl-sql子程序簡介五_第4頁
oracle學習-pl-sql子程序簡介五_第5頁
免費預覽已結束,剩余15頁可下載查看

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

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. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論