亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Oracle > 正文

全面解析Oracle Procedure 基本語法

2024-08-29 13:59:41
字體:
來源:轉載
供稿:網友

關鍵字: oracle/202784.html">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知識,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!


注:相關教程知識閱讀請移步到oracle教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品理论电影| 国产精品精品国产| 亚洲片国产一区一级在线观看| 国产一区二区美女视频| 91系列在线播放| 欧美精品日韩www.p站| 亚洲激情电影中文字幕| 美女国内精品自产拍在线播放| 欧美成人午夜激情| 日韩一区在线视频| 日本欧美中文字幕| 国产91精品不卡视频| 久久久久久久久久亚洲| 亚洲最新视频在线| 欧美在线视频导航| 日韩一区二区三区国产| 91精品国产自产91精品| 亚洲区免费影片| 91精品国产免费久久久久久| 亚洲精品久久久久久下一站| 亚洲qvod图片区电影| 亚洲欧洲激情在线| 777午夜精品福利在线观看| 欧美日韩综合视频网址| 欧美乱大交xxxxx| 日韩欧美精品中文字幕| 亚洲天堂久久av| 久久久成人精品| 国产精品福利观看| 欧美日韩成人在线视频| 亚洲成人免费网站| 日韩精品视频在线观看免费| 国产一区二区三区高清在线观看| 久久久久久久国产精品视频| 日韩欧美国产中文字幕| 日韩av在线免费观看| 欧美激情网站在线观看| 91精品国产综合久久久久久蜜臀| 欧美亚洲免费电影| 国产成人精彩在线视频九色| 国产精品视频久| 成人妇女淫片aaaa视频| 在线视频免费一区二区| 亚洲人成网站777色婷婷| 一区二区三区亚洲| 亚洲国产一区二区三区在线观看| 亚洲免费视频一区二区| 久久精品在线视频| 国产精品视频999| 亚洲日本欧美日韩高观看| 亚洲tv在线观看| 国产视频久久久久久久| 亚洲人精选亚洲人成在线| 91精品视频观看| 91久久久久久久久久久久久| 成人免费网站在线观看| 日韩一区二区福利| 久久久亚洲福利精品午夜| 欧美性生活大片免费观看网址| 欧美日韩免费网站| 78色国产精品| 中文字幕自拍vr一区二区三区| 亚洲成人在线视频播放| 91国自产精品中文字幕亚洲| 国产精品中文字幕久久久| 97在线日本国产| 美女扒开尿口让男人操亚洲视频网站| 26uuu日韩精品一区二区| 久久久久国产视频| 久久精品99无色码中文字幕| 岛国av一区二区在线在线观看| 欧美性生交大片免网| 日韩小视频在线观看| 成人国产精品免费视频| 精品一区精品二区| 欧美黑人国产人伦爽爽爽| 欧美成aaa人片免费看| yw.139尤物在线精品视频| 狠狠做深爱婷婷久久综合一区| 日韩精品在线视频| 亚洲xxx视频| 97精品视频在线| 国产亚洲激情在线| 96pao国产成视频永久免费| 欧美午夜视频在线观看| 国产伦精品一区二区三区精品视频| 亚洲图片在线综合| 欧美一性一乱一交一视频| 国产精品免费视频xxxx| 成人中心免费视频| 奇米成人av国产一区二区三区| 色悠悠国产精品| 韩日精品中文字幕| 在线视频免费一区二区| 亚洲片国产一区一级在线观看| 国产精品视频一区二区高潮| 尤物精品国产第一福利三区| 国产欧美在线播放| 国产欧美亚洲视频| 亚洲аv电影天堂网| 国内精品小视频在线观看| 色噜噜亚洲精品中文字幕| 琪琪亚洲精品午夜在线| 久久亚洲精品一区| 精品亚洲精品福利线在观看| 亚洲免费一在线| 欧美xxxx做受欧美.88| 7777kkkk成人观看| 亚洲男人天堂古典| 91精品视频大全| 亚洲伊人一本大道中文字幕| 91精品中国老女人| 久久久久久网址| 久久久国产一区| 亚洲天堂av在线播放| 亚洲网在线观看| 国产精品揄拍500视频| 欧美日韩国产999| 亚洲精品综合精品自拍| 日韩在线视频免费观看高清中文| 亚洲免费影视第一页| 欧美国产欧美亚洲国产日韩mv天天看完整| 红桃视频成人在线观看| 国产精品久久久久7777婷婷| 国产精品27p| 日韩少妇与小伙激情| 原创国产精品91| 91国产视频在线| 日韩av理论片| 亚洲精品午夜精品| 国产精品一区二区电影| 欧美黄色三级网站| 亚洲精品日韩在线| 精品国产乱码久久久久久虫虫漫画| 日韩av最新在线| 8050国产精品久久久久久| 成人福利网站在线观看11| 91在线视频免费| 岛国av在线不卡| 国产精欧美一区二区三区| 国产不卡一区二区在线播放| 北条麻妃在线一区二区| 国产精品亚洲一区二区三区| 日韩极品精品视频免费观看| 成人精品久久久| 国产在线精品一区免费香蕉| 国产精品久久999| 丝袜美腿精品国产二区| 久久久亚洲影院| 国产视频观看一区| 国产精品视频内| 欧美日韩精品在线视频| 国产综合在线看| 国产精品欧美风情| 欧美高跟鞋交xxxxxhd| 日韩av大片免费看| 日本三级久久久| 色综合五月天导航| 日韩欧美亚洲综合| 国产免费观看久久黄| 国产精品日本精品| 国产精品高精视频免费| 韩剧1988在线观看免费完整版| 美女999久久久精品视频|