全面解析Oracle Procedure 基本语法

论坛 期权论坛 脚本     
niminba   2021-5-23 04:58   1910   0

关键字: 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_declc[J	f9i#{JN[[[YNY\H[[
Y\H\\H[\	]\NYX[\H[\\H[\Y\]][J	f9ma;\JN[[[[[[W]JY\H]\]H\Y]H[\\Y]I]\NYX\Y]H[Y]H[\\H[\Y]\Y]N[[W]N[XOB]B/, "!y.+yb&:/"lB]\HHBH\H\B^XX[[YJ

N^XX[[


NXX[W]J

HX[OB]B/%9n+y.9!b&!z) B]\HHBH\H\BX]H\XXYX\\\]\[\	\\NY\H[X\OB]Bb&!y..B]\HHBH\H\BX]H\XXYHX\\\]\[\	\\H\X
[\Y\H\X[\[\	\\NY[\]\[X[\^][\	[YX[\	[\]][J	a;X[\	 9b9`#ybb幣a	[X[\	L[X[\	[\]][J	a;X[\	a9. :"+;.yc幤'.*`!`f`f[\]][J	a;X[\	a9.#ze&{.yc幤'.*.!`f`f[Y[[[X\OB]B, "!y.+y/" "!y.+y.9!B]\HHBH\H\B^XX\OB]B/;kf9`:/"繮.9!d9ni9n眗\.9!B]\HHBH\H\BPUHTPXY\\H^]\H\YY\H
^X^]\JN[PUHTPXYH\Y\H
^X^]\JH\\^]\NY[\X
[\^X\\[[OB]B蹧"yal"l9d9n9/kB]\HHBH\H\BTPkke[[X[YHX]LNXX[YKX\H\X\HX\H[
	QTISSPQPQIOB]B."`:/+%i)XHY\y+#9n#9&)"y`9n+b{i9i)"y.eye$y* ;l#&c#yi)8g*9i9.g.9')/c.+ O
分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:1060120
帖子:212021
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP