Oracle procedure 基本文法

來源:互聯網
上載者:User

標籤:item   密碼   列表   最好   工資   程式包   create   資源   pen   

 

轉自:http://lorry1113.javaeye.com/blog/513851

關鍵字: oracle 預存程序 

1.基本結構 CREATE OR REPLACE PROCEDURE 預存程序名字 (     參數1 IN NUMBER,     參數2 IN NUMBER ) IS 變數1 INTEGER :=0; 變數2 DATE; BEGIN 
END 預存程序名字 
2.SELECT INTO STATEMENT   將select查詢的結果存入到變數中,可以同時將多個列儲存多個變數中,必須有一條   記錄,否則拋出異常(如果沒有記錄拋出NO_DATA_FOUND)   例子:   BEGIN   SELECT col1,col2 into 變數1,變數2 FROM typestruct where xxx;   EXCEPTION   WHEN NO_DATA_FOUND THEN       xxxx;   END;   ... 
3.IF 判斷   IF V_TEST=1 THEN     BEGIN        do something     END;   END IF; 
4.while 迴圈   WHILE V_TEST=1 LOOP   BEGIN XXXX   END;   END LOOP; 
5.變數賦值   V_TEST := 123; 
6.用for in 使用cursor   ...   IS   CURSOR cur IS SELECT * FROM xxx;   BEGIN FOR cur_result in cur LOOP   BEGIN    V_SUM :=cur_result.列名1+cur_result.列名2   END; END LOOP;   END; 
7.帶參數的cursor   CURSOR C_USER(C_ID NUMBER) IS SELECT NAME FROM USER WHERE TYPEID=C_ID;   OPEN C_USER(變數值);   LOOP FETCH C_USER INTO V_NAME; EXIT FETCH C_USER%NOTFOUND;     do something   END LOOP;   CLOSE C_USER; 
8.用pl/sql developer debug   串連資料庫後建立一個Test WINDOW   在視窗輸入調用SP的代碼,F9開始debug,CTRL+N單步調試 轉載:oracle 預存程序關鍵字: oracle 預存程序 預存程序建立文法: 
       create or replace procedure 預存程序名(param1 in type,param2 out type) 
as 
變數1 類型(值範圍); 
變數2 類型(值範圍); 
Begin 
    Select count(*) into 變數1 from 表A where列名=param1; 
    If (判斷條件) then 
       Select 列名 into 變數2 from 表A where列名=param1; 
       Dbms_output。Put_line(‘列印資訊’); 
    Elsif (判斷條件) then 
       Dbms_output。Put_line(‘列印資訊’); 
    Else 
       Raise 異常名(NO_DATA_FOUND); 
    End if; 
Exception 
    When others then 
       Rollback; 
End; 

注意事項: 
1,  預存程序參數不帶取值範圍,in表示傳入,out表示輸出 
2,  變數帶取值範圍,後面接分號 
3,  在判斷語句前最好先用count(*)函數判斷是否存在該條操作記錄 
4,  用select 。。。into。。。給變數賦值 
5,  在代碼中拋異常用 raise+異常名 

以命名的異常 
命名的系統異常                          產生原因 
ACCESS_INTO_NULL                   未定義對象 
CASE_NOT_FOUND                     CASE 中若未包含相應的 WHEN ,並且沒有設定 
ELSE 時 
COLLECTION_IS_NULL                集合元素未初始化 
CURSER_ALREADY_OPEN          遊標已經開啟 
DUP_VAL_ON_INDEX                   唯一索引對應的列上有重複的值 
INVALID_CURSOR                 在不合法的遊標上進行操作 
INVALID_NUMBER                       內嵌的 SQL 陳述式不能將字元轉換為數字 
NO_DATA_FOUND                        使用 select into 未返回行,或應用索引表未初始化的 

TOO_MANY_ROWS                      執行 select into 時,結果集超過一行 
ZERO_DIVIDE                              除數為 0 
SUBSCRIPT_BEYOND_COUNT     元素下標超過巢狀表格或 VARRAY 的最大值 
SUBSCRIPT_OUTSIDE_LIMIT       使用巢狀表格或 VARRAY 時,將下標指定為負數 
VALUE_ERROR                             賦值時,變數長度不足以容納實際資料 
LOGIN_DENIED                           PL/SQL 應用程式串連到 oracle 資料庫時,提供了不 
正確的使用者名稱或密碼 
NOT_LOGGED_ON                       PL/SQL 應用程式在沒有串連 oralce 資料庫的情況下 
訪問資料 
PROGRAM_ERROR                       PL/SQL 內部問題,可能需要重裝資料字典& pl./SQL 
系統包 
ROWTYPE_MISMATCH                宿主遊標變數與 PL/SQL 遊標變數的傳回型別不相容 
SELF_IS_NULL                             使用物件類型時,在 null 對象上調用對象方法 
STORAGE_ERROR                        運行 PL/SQL 時,超出記憶體空間 
SYS_INVALID_ID                         無效的 ROWID 字串 
TIMEOUT_ON_RESOURCE         Oracle 在等待資源時逾時  文法及樣本:1、預存程序建立預存程序的文法:CREATE [OR REPLACE] PROCEDURE procedure_name[(parameter_list)]{IS|AS}[local_declarations]BEGINexecutable_statements[EXCEPTIONexception_handlers]END [procedure_name];其中:procedure_name是過程的名稱。parameter_list是參數列表。local_declarations是局部聲明。executable_statements是可執行語句。exception_handlers是例外處理常式。樣本1:示範建立過程(參數列表中為IN參數賦予一個預設值,不能為OUT、IN OUT參數賦予預設值)create or replace procedure find_emp(emp_no in number:=7900)asempname varchar2(20);beginselect ename into empname from emp where empno=emp_no;dbms_output.put_line(‘僱員姓名是 ‘||empname);exceptionwhen no_data_found thendbms_output.put_line(‘僱員編號未找到‘);end find_emp;調用過程:EXECUTE procudure_name(parameters_list);也可以在過程裡面調用,直接寫上procudure_name而不必寫EXECUTE。

樣本2:示範建立帶OUT參數的過程 create or replace procedure test(value1 varchar2,value2 out number) is identity number; begin select sal into identity from emp where empno=value1; if identity<2000 then value2:=1000; else value2:=500; end if; end;

調用帶OUT參數的過程: declare value2 number; begin test(‘7900‘,value2); dbms_output.put_line(value2); end;

樣本3:示範建立帶IN OUT參數的過程 create or replace procedure swap(p1 in out number,p2 in out number) is v_temp number; begin v_temp:=p1; p1:=p2; p2:=v_temp; end;

調用帶IN OUT參數的過程: declare num1 number:=100; num2 number:=200; begin swap(num1,num2); dbms_output.put_line(‘num1= ‘||num1); dbms_output.put_line(‘num2= ‘||num2); end;

樣本4:將過程的執行許可權授予其他使用者 GRANT EXECUTE ON find_emp TO scott; GRANT EXECUTE ON swap TO PUBLIC; 將find_emp過程的執行許可權授予給使用者scott,將執行swap過程的許可權授予所有資料庫使用者。 刪除過程文法:DROP PROCEDURE procudure_name;

2、函數 定義函數的文法如下: CREATE [OR REPLACE] FUNCTION function_name [(parameter_list)] RETURN datatype {IS|AS} [local_declarations] BEGIN executable_statements [EXCEPTION exception_handlers] END [function_name]; 其中:function_name是函數的名稱。 parameter_list是參數列表。 local_declarations是局部聲明。 executable_statements是可執行語句。 exception_handlers是例外處理常式。 使用函數時注意:形式參數必須只使用資料庫類型,不得使用PL/SQL類型。函數的傳回型別也必須是資料庫類型。 函數不能單獨執行,只能通過SQL語句或PL/SQL程式塊來調用。 樣本5:示範如何建立函數 create or replace function fun_hello return varchar2 is begin return ‘朋友,您好‘; end; 調用函數:select fun_hello from dual;

函數的授權:同過和的授權一樣具體請看樣本4。 刪除函數:DROP FUNCTION function_name

過程和函數的差異 過程 函數 作為PL/SQL語句執行 作為運算式的一部分調用 在規範中不包含RETURN子句 必須在規範中包含RETURN子句 不返回任何值 必須返回單個值 可以包含RETURN語句,但是與函數不同,它不能用於傳回值 必須包含至少一條RETURN語句

3、程式包 建立包規範的文法: CREATE [OR REPLACE] PACKAGE package_name IS|AS [Public type and item declarations] [Subprogram specifications] END [package_name]; 其中:package_name是包的名稱。 Public type and item declarations是宣告類型、常量、變數、異常和遊標等。 Subprogram specifications聲明PL/SQL子程式。 樣本6:示範建立程式包規範 create or replace package pack_op is procedure pro_print_ename(id number); procedure pro_print_sal(id number); function fun_re_date(id number) return date; end;

建立包主體的文法: CREATE [OR REPLACE] PACKAGE BODY package_name IS|AS [Public type and item declarations] [Subprogram bodies] [BEGIN Initialization_statements] END [package_name]; 其中:package_name是包的名稱。 Public type and item declarations是宣告類型、常量、變數、異常和遊標等。 Subprogram bodies是定義公用和私人PL/SQL子程式。

樣本7:示範建立程式包主體 create or replace package body pack_op is procedure pro_print_ename(id number) is name emp.ename%type; begin select ename into name from emp where empno=id; dbms_output.put_line(‘職員姓名:‘||name); end pro_print_ename; procedure pro_print_sal(id number) is salary emp.sal%type; begin select sal into salary from emp where empno=id; dbms_output.put_line(‘職員工資:‘||salary); end pro_print_sal; function fun_re_date(id number) return date is bedate emp.hiredate%type; begin select hiredate into bedate from emp where empno=id; return bedate; end fun_re_date; end pack_op;

樣本8:調用程式包中建立的過程和函數 exec pack_op.pro_print_ename(7900); exec pack_op.pro_print_sal(7900); select pack_op.fun_re_date(7900) from dual;

樣本9:示範程式包中的遊標 建立包規範 create or replace package pack_emp is cursor cur_emp return emp%rowtype; procedure pro_cur; end pack_emp;

建立包主體 create or replace package body pack_emp is cursor cur_emp return emp%rowtype is select * from emp; procedure pro_cur is rec_emp emp%rowtype; begin open cur_emp; loop fetch cur_emp into rec_emp; exit when cur_emp%notfound; if rec_emp.sal<1000 then dbms_output.put_line(‘員工工資:‘||rec_emp.sal||‘,需加倍努力爭取提高工資‘); elsif rec_emp.sal>=1000 and rec_emp.sal<2000 then dbms_output.put_line(‘員工工資:‘||rec_emp.sal||‘,工資一般,爭取搞個部門經理做做‘); else dbms_output.put_line(‘員工工資:‘||rec_emp.sal||‘,工資不錯,爭取搞個總經理做做‘); end if; end loop; end pro_cur; end pack_emp;

調用程式包中的過程以調用程式包中的遊標 exec pack_emp.pro_cur;

樣本10:預存程序返回遊標的子程式包(此程式包返回r_cur遊標) CREATE OR REPLACE package SCOTT.pk_wt is type mytype is ref cursor; procedure p_wt(mycs out mytype); end;

CREATE OR REPLACE package BODY SCOTT.pk_wt is procedure p_wt(mycs out mytype) is r_cur mytype; begin open r_cur for select * from emp; mycs:=r_cur; end p_wt; end pk_wt;

查詢有關過程、函數和程式包的資訊:USER_OBJECTS資料字典視圖 column object_name format a18 select object_name,object_type from user_objects where object_type in (‘PROCEDURE‘,‘FUNCTION‘,‘PACKAGE‘,‘PACKAGE BODY‘);

Oracle procedure 基本文法

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.