zoukankan      html  css  js  c++  java
  • oracle无参数和带参数的存储过程实例

    SQL中调用存储过程语句:call procedure_name();

    注:调用时”()”是不可少的,无论是有参数还是无参数.

                

    定义对数据库存储过程的调用时
    1、无参数存储过程:{call procedure_name}
    2、仅有输入参数的存储过程:{call procedure_name(?,?...)}。
    这里?表示输入参数,创建存储过程时用in表示输入参数
    3、仅有输出参数的存储过程:{call procedure_name(?,?...)}。
    这里的?表示输出参数,创建存储过程时用out表示输出参数
    4、既有输入参数又有输出参数的存储过程{call procedure_name(?,?...)}。
    这里的?有表示输出参数的,也有表示输入参数的

               

    下面将会对这4种情况分别举出实例!!!
    1、无参数存储过程
    复制代码
    CREATEORREPLACEPROCEDURE stu_proc AS
    --声明语句段
    v_name VARCHAR2(20);
    BEGIN
    --执行语句段
    SELECT o.sname INTO v_name FROM student o WHERE o.id=4;
    dbms_output.put_line(v_name);
    EXCEPTION
    --异常处理语句段
    WHEN NO_DATA_FOUND THEN dbms_output.put_line('NO_DATA_FOUND');
    END;
    复制代码
                       
    2、仅带入参的存储过程
    复制代码
    CREATEORREPLACEPROCEDURE stu_proc(v_id IN student.id%type) AS
    --声明语句段
    v_name varchar2(20);
    BEGIN
    --执行语句段
    SELECT o.sname INTO v_name FROM student o where o.id=v_id;
    dbms_output.put_line(v_name);
    EXCEPTION
    --异常处理语句段
    WHEN NO_DATA_FOUND THEN dbms_output.put_line('NO_DATA_FOUND');
    END;
    复制代码
                  
    3、仅带出参的存储过程 
    复制代码
    --此种存储过程不能直接用call来调用,这种情况的调用将在下面oracle函数调用中说明
    CREATEORREPLACEPROCEDURE stu_proc(v_name OUT student.sname%type) AS
    --声明语句段
    BEGIN
    --执行语句段
    SELECT o.sname INTO v_name FROM student o where o.id=1;
    dbms_output.put_line(v_name);
    EXCEPTION
    --异常处理语句段
    WHEN NO_DATA_FOUND THEN dbms_output.put_line('NO_DATA_FOUND');
    END;
    复制代码
               
    4、带入参和出参的存储过程
    复制代码
    --此种存储过程不能直接用call来调用,这种情况的调用将在下面oracle函数调用中说明
    CREATEORREPLACEPROCEDURE stu_proc(v_id IN student.id%type, v_name OUT student.sname%type) AS
    --声明语句段
    BEGIN
    --执行语句段
    SELECT o.sname INTO v_name FROM student o where o.id=v_id;
    dbms_output.put_line(v_name);
    EXCEPTION
    --异常处理语句段
    WHEN NO_DATA_FOUND THEN dbms_output.put_line('NO_DATA_FOUND');
    END;
  • 相关阅读:
    一个编译器的实现0
    《穿越计算机的迷雾》笔记
    C#WinForm应用程序实现自动填充网页上的用户名和密码并点击登录按钮
    一个编译器的实现2——从文法到LL(1)分析表的概念和算法
    使用百度地图API的例子
    过桥问题 Bridge and torch problem
    (译)跟媳妇解释面向对象设计
    批量照片缩小器展示多线程控件BackgroundWorker后台工作使用方法
    图解:邮件(消息)的加密解密和数字签名
    一个编译器的实现1——开篇
  • 原文地址:https://www.cnblogs.com/shaohz2014/p/3713408.html
Copyright © 2011-2022 走看看