Oracle存储过程学习

引自http://blog.csdn.net/happyxjg/archive/2009/08/07/4419353.aspx

 

1.基本结构

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单步调试

存储过程 包含三部分: 声明,执行部分,异常。    
可以有无参数程序和带参数存储过程。    
无参程序语法    
1 create or replace procedure NoParPro   
2 as   ;   
3 begin   
4  ;   
5 exception   
6      ;   
7 end;   
8    
  
   带参存储过程实例    
 1 create or replace procedure queryempname(sfindno emp.empno%type) as   
 2        sName emp.ename%type;   
 3        sjob emp.job%type;   
 4 begin   
 5        ....   
 7 exception   
          ....   
14 end;   
15    
  
   带参数存储过程含赋值方式    
 1 create or replace procedure runbyparmeters  (isal in emp.sal%type,    
                            sname out varchar,sjob in out varchar)   
 2  as icount number;   
 3  begin   
 4       select count(*) into icount from emp where sal>isal and job=sjob;   
 5       if icount=1 then   
 6         ....   
 9       else  
10         ....   
12       end if;   
13  exception   
14       when too_many_rows then   
15       DBMS_OUTPUT.PUT_LINE('返回值多于1行');   
16       when others then   
17       DBMS_OUTPUT.PUT_LINE('在RUNBYPARMETERS过程中出错!');   
18  end;   
19    
  
  过程调用   
  方式一   
 1 declare   
 2        realsal emp.sal%type;   
 3        realname varchar(40);   
 4        realjob varchar(40);   
 5  begin   
 6        realsal:=1100;   
 7        realname:='';   
 8        realjob:='CLERK';   
 9        runbyparmeters(realsal,realname,realjob);     --必须按顺序   
10        DBMS_OUTPUT.PUT_LINE(REALNAME||'   '||REALJOB);   
11  END;   
12    
  
  方式二   
 1 declare   
 2       realsal emp.sal%type;   
 3       realname varchar(40);   
 4       realjob varchar(40);   
 5 begin   
 6       realsal:=1100;   
 7       realname:='';   
 8       realjob:='CLERK';   
 9       runbyparmeters(sname=>realname,isal=>realsal,sjob=>realjob);  --指定值对应变量顺序可变   
10       DBMS_OUTPUT.PUT_LINE(REALNAME||'   '||REALJOB);   
11 END;   
12   


存储过程创建语法:
 
       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 在等待资源时超时


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/happyxjg/archive/2009/08/07/4419353.aspx

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值