zoukankan      html  css  js  c++  java
  • Oracle存储过程

    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);// 有返回值过程调用  
  • 相关阅读:
    sizeof运算符介绍以及常见的坑
    程序员面试需要带身份证和毕业证原件吗
    CentOS7配置rsync实现文件同步
    CentOS7配置samba共享文件系统
    freecplus框架-字符串操作
    freecplus框架-文件操作
    freecplus框架-日志文件操作
    freecplus框架-日期、时间和计时器
    Unix 网络编程卷一源码编译踩坑记录 ubtutu 19.10
    实时人流量监测——海康威视sdk初体验
  • 原文地址:https://www.cnblogs.com/momoyan/p/9156495.html
Copyright © 2011-2022 走看看