• Oracle存储过程


    转载:https://blog.csdn.net/u013057786/article/details/17165623

    1、定义
    所谓存储过程(Stored Procedure),就是一组用于完成特定数据库功能的SQL语句集,该SQL语句集经过
    编译后存储在数据库系统中。在使用时候,用户通过指定已经定义的存储过程名字并给出相应的存储过程参数
    来调用并执行它,从而完成一个或一系列的数据库操作。

    2、存储过程的创建
    Oracle存储过程包含三部分:过程声明,执行过程部分,存储过程异常。

    (1)无参存储过程语法

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

    (2)带参存储过程实例

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

    (3)带参数存储过程含赋值方式

    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  
           ....  
         end if;  
    exception  
         when too_many_rows then  
         DBMS_OUTPUT.PUT_LINE('返回值多于1行');  
         when others then  
         DBMS_OUTPUT.PUT_LINE('在RUNBYPARMETERS过程中出错!');  
    end;

    其中参数IN表示输入参数,是参数的默认模式。
    OUT表示返回值参数,类型可以使用任意Oracle中的合法类型。
    OUT模式定义的参数只能在过程体内部赋值,表示该参数可以将某个值传递回调用他的过程
    IN OUT表示该参数可以向该过程中传递值,也可以将某个值传出去。

    (4)存储过程中游标定义使用

    as //定义(游标一个可以遍历的结果集)   
    CURSOR cur_1 IS   
      SELECT area_code,CMCODE,SUM(rmb_amt)/10000 rmb_amt_sn,  
             SUM(usd_amt)/10000 usd_amt_sn   
      FROM BGD_AREA_CM_M_BASE_T   
      WHERE ym >= vs_ym_sn_beg   
           AND ym <= vs_ym_sn_end   
      GROUP BY area_code,CMCODE;   
          
    begin //执行(常用For语句遍历游标)       
    FOR rec IN cur_1 LOOP   
      UPDATE xxxxxxxxxxx_T   
       SET rmb_amt_sn = rec.rmb_amt_sn,usd_amt_sn = rec.usd_amt_sn   
       WHERE area_code = rec.area_code   
       AND CMCODE = rec.CMCODE   
       AND ym = is_ym;   
    END LOOP;

    (5)游标的定义

    --显示cursor的处理
    declare  
    ---声明cursor,创建和命名一个sql工作区
    cursor cursor_name is  
        select real_name from account_hcz;
        v_realname varchar2(20);
    begin 
        open cursor_name;---打开cursor,执行sql语句产生的结果集
        fetch cursor_name into v_realname;--提取cursor,提取结果集中的记录
        dbms_output.put_line(v_realname);
        close cursor_name;--关闭cursor
    end;

    3、在Oracle中对存储过程的调用 

    (1)过程调用方式一

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

    (2)过程调用方式二

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

    (3)过程调用方式三(SQL命令行方式下)

    1、SQL>exec  proc_emp('参数1','参数2');//无返回值过程调用  
    2、SQL>var vsal number  
         SQL> exec proc_emp ('参数1',:vsal);// 有返回值过程调用  
          或者:call proc_emp ('参数1',:vsal);// 有返回值过程调用  
  • 相关阅读:
    微信支付收款限制
    手机自动化截图调试工具——PhotoShop
    ZipSecureFile$ThresholdInputStream cannot be cast to java.base/java.util.zip.ZipFile$ZipFileInputStream
    [Leetcode题解]605. 种花问题-贪心算法+卫语句重构
    「问题修复」「cargo」warning: spurious network error (2 tries remaining): [6] Couldn't resolve host name (Could not resolve host: crates)
    久坐程序员,简单高效的保命技巧,以及某人久坐的惨样
    [Leetcode题解]2. 两数相加-链表遍历和重构
    Go语言基础知识01-用Go打个招呼
    【Qt Tips】QLineEdit内容过滤之setValidator和setInputMask浅析
    Ubuntu12.10 使用JLink连接开发板用arm-gdb调试ARM程序
  • 原文地址:https://www.cnblogs.com/masterhxh/p/13921932.html
Copyright © 2020-2023  润新知