zoukankan      html  css  js  c++  java
  • 存储过程格式及实例

    pl/sql 存储过程(procedure)

    格式:
    declare    --(可选项,用于声明变量)
    ……
    begin
    ……
    exception --(异常处理)
    ……
    end

    /--运行
    pl/sql要运行输出语句的话,需要先
     set serveroutput on;
     实例1(打印hello world).
     declare
      2  x varchar2(20);
      3  begin
      4  x := 'hello world';
      5  dbms_output.put_line('x的值为:'||x);
      6  end;
      7  /
     
      运行结果:
      x的值为:hello world
      PL/SQL procedure successfully completed
      实例2(简单for循环)
       set serveroutput on;
       begin
       for i in 1..5 loop
       DBMS_output.put_line('i='||i);
       end loop;
       end;
       /

       实例3(if elsif else)
         declare
         x number;
         begin
         x := 0;
         if x>0 then
         dbms_output.put_line(x||'大于0');
         elsif x<0 then
         dbms_output.put_line(x||'小于0');
         else
         dbms_output.put_line(x||'等于0');
         end if;
         end;
         /
      运行结果: 0等于0
                PL/SQL procedure successfully completed
        
      实例4(goto的应用)
       declare
       x number;
       begin
       x := 0;
       <<a_loop>>
       x := x+1;
       dbms_output.put_line('x=  '||x);
       if x<3 then
       goto a_loop;
       end if;
       end;
       /
    运行结果:
    x=  1
    x=  2
    x=  3
    PL/SQL procedure successfully completed

    实例5(自定义异常并且抛出)
      declare
     test varchar2(20);
     e excetpion;
     begin
     select wtdempname into test from westemp  where wtdempid= 6;
     if test <> 'KING' then
     raise e;
     end if;
     dbms_output.put_line('wtdempname=   '||test);
     exception
     when e then
     dbms_output.put_line('报错了..');
     end;
     /

    实例6(特殊数据类型--记录 的定义1及应用)

     set serveroutput on;
     declare
     myrecord westemp%rowtype;
     begin
     select * into myrecord from westemp where wtdempid= 6;
     dbms_output.put_line('wtdempname=  '||myrecord.wtdempname);
     end;
     /
    运行结果:
    wtdempname=  f
    PL/SQL procedure successfully completed

    实例7(特殊数据类型--记录 的定义2及应用)
      set serveroutput on;
      declare
      type myrecord is record(
      id number(5),
      name varchar2(20)
      );
      test_record myrecord;
      begin
      select wtdempid,wtdempname into test_record from westemp where wtdempid=6;
      dbms_output.put_line('wtdempid=  '||test_record.id||',  wtdempname=  '||test_record.name);
      end;
      /
    运行结果:
    wtdempid=  6,  wtdempname=  f
    PL/SQL procedure successfully completed

    实例8(显示游标的定义及应用)
    SQL> set serveroutput on;
    SQL> declare
      2  cursor mycur is select * from westemp where wtddeptid=4;
      3  myrecord westemp%rowtype;
      4  begin
      5  open mycur;
      6  fetch mycur into myrecord;
      7  while mycur%found loop
      8  dbms_output.put_line('wtdempid=  '||myrecord.wtdempid||',  wtdempname=  '||myrecord.wtdempname||',   wtddeptid=   '||myrecord.wtddeptid);
      9  fetch mycur into myrecord;
     10  end loop;
     11  close mycur;
     12  end;
     13  /
    运行结果:
    wtdempid=  15,  wtdempname=  o,   wtddeptid=   4
    wtdempid=  3,  wtdempname=  c,   wtddeptid=   4
    wtdempid=  7,  wtdempname=  g,   wtddeptid=   4
    wtdempid=  12,  wtdempname=  l,   wtddeptid=   4
    PL/SQL procedure successfully completed
    注意:游标的常用属性有:%found,%isopen,%notfound,%rowcount。

    实例9  (带参数的显示游标和隐式游标)

    SQL> set serveroutput on;
    SQL> declare
      2   cursor cur_param(no number) is
      3  select wtdempname from westemp where wtddeptid=no;
      4  begin
      5  dbms_output.put_line('result set is  ');
      6  for cur in cur_param(4) loop
      7  dbms_output.put_line('wtdempname=  '||cur.wtdempname);
      8  end loop;
      9  end;
     10  /
    运行结果:
    result set is  
    wtdempname=  o
    wtdempname=  c
    wtdempname=  g
    wtdempname=  l
    PL/SQL procedure successfully completed

    实例10 (隐式游标)
    隐式游标不需要在declare块中先是声明定义,也不需要手动打开和关闭,一个简单的隐式游标的例子如下:
    SQL> begin
      2  for cur in (select wtdempname from westemp) loop  --此处的cur就是隐式游标
      3  dbms_output.put_line('wtdempname=  '||cur.wtdempname);
      4  end loop;
      5  end;
      6  /
    运行结果:
    wtdempname=  o
    wtdempname=  a
    wtdempname=  b
    wtdempname=  c
    wtdempname=  d
    wtdempname=  e
    wtdempname=  f
    wtdempname=  g
    wtdempname=  h
    wtdempname=  i
    wtdempname=  j
    wtdempname=  k
    wtdempname=  l
    wtdempname=  m
    wtdempname=  n
    PL/SQL procedure successfully completed

    实例11 (存储过程的创建和调用)
    创建
    SQL> create or replace procedure westProc(no in number,name out varchar2)
      2  is
      3  begin
      4  select wtdempname into name  from westemp where wtdempid=no ;
      5  end;
      6  /
    Procedure created
    调用
    SQL> set serveroutput on;
    SQL> declare
      2  no number;
      3  name varchar2(20);
      4  begin
      5  westProc(6,name);
      6  dbms_output.put_line('name=  '||name);
      7  end;
      8  /
    name=  f
    PL/SQL procedure successfully completed

    执行存储过程:

    存储过程的调用有以下三种方法:

    a.在PL/SQL中调用,如:
    begin
    myProc(7900);
    end;
    /
    b.使用call来调用,如:
    call myProc(7900);
    c.通过execute调用,如:
    execute myProc(7900);
    注意:execute调用存储过程时,要么不带任何参数,要么只能是输入参数。

  • 相关阅读:
    剑指offer_24:二叉树中和为某一值的路径
    剑指offer_23:二叉搜索树的后序遍历序列
    Java基础类型大小
    旋转数组
    剑指offer_22:从上往下打印二叉树
    剑指offer_21:栈的压入、弹出序列
    剑指offer_20:包含min函数的栈
    剑指offer_19:顺时针打印矩阵
    剑指offer_18:二叉树的镜像
    redis jedis源码
  • 原文地址:https://www.cnblogs.com/westward/p/5199247.html
Copyright © 2011-2022 走看看