ITPub博客

首页 > 数据库 > Oracle > Oracle存储过程【转载】

Oracle存储过程【转载】

Oracle 作者:VigorStarHuwei 时间:2011-11-22 22:39:34 0 删除 编辑

Oracle存储过程包含三部分:过程声明,执行过程部分,存储过程异常。

Oracle存储过程可以有无参数存储过程和带参数存储过程。 
、无参程序过程语法

create or replace procedure NoParPro
as  ;
begin
;
exception     //存储过程异常
    ;
end;


        二、带参存储过程实例

 create or replace procedure queryempname(sfindno emp.empno%type) as
        sName emp.ename%type;
        sjob emp.job%type;
 begin
        ....
 exception
          ....
14 end;
15 


    三、 带参数存储过程含赋值方式

 create or replace procedure runbyparmeters  (isal in emp.sal%type,
                            sname out varchar,sjob in out varchar)
  as icount number;
  begin
       select count(*) into icount from emp where sal>isal and job=sjob;
       if icount=1 then
         ....
       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 


  四、在Oracle中对存储过程的调用
  过程调用方式一

 declare
        realsal emp.sal%type;
        realname varchar(40);
        realjob varchar(40);
  begin   //存储过程调用开始
        realsal:=1100;
        realname:='';
        realjob:='CLERK';
        runbyparmeters(realsal,realname,realjob);     --必须按顺序
10        DBMS_OUTPUT.PUT_LINE(REALNAME||'   '||REALJOB);
11  END;  //过程调用结束
12 


  过程调用方式二

 declare
       realsal emp.sal%type;
       realname varchar(40);
       realjob varchar(40);
 begin    //过程调用开始
       realsal:=1100;
       realname:='';
       realjob:='CLERK';
       runbyparmeters(sname=>realname,isal=>realsal,sjob=>realjob);  --指定值对应变量顺序可变
10       DBMS_OUTPUT.PUT_LINE(REALNAME||'   '||REALJOB);
11 END;  //过程调用结束
12 

 至此,有关ORACLE的基本存储过程以及对Oracle存储过程的调用方式介绍完毕。

<!-- 正文结束 -->

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/21679819/viewspace-1116963/,如需转载,请注明出处,否则将追究法律责任。

上一篇: 没有了~
下一篇: 没有了~
请登录后发表评论 登录
全部评论

注册时间:2009-05-18