zoukankan      html  css  js  c++  java
  • oracle函数调用存储过程

    1、无参数存储过程的调用

    --创建无参存储过程
    CREATE OR REPLACE FUNCTION stu_proc RETURN VARCHAR2 IS
    --声明语句段
    v_name varchar2(20);
    BEGIN
    --执行语句段
    SELECT o.sname INTO v_name FROM student o where o.id=1;
    RETURN v_name;
    END;

    --调用无参存储过程
    DECLARE
    BEGIN
    DBMS_OUTPUT.put_line(
    '在PL/SQL中打印的结果:'||stu_proc);
    END;

               

     

    2、入参存储过程的调用

    --创建入参存储过程
    CREATE OR REPLACE FUNCTION stu_proc(v_id IN NUMBER) RETURN VARCHAR2 IS
    --声明语句段
    v_name varchar2(20);
    BEGIN
    --执行语句段
    SELECT o.sname INTO v_name FROM student o where o.id=v_id;
    RETURN v_name;
    END;

    --调用入参存储过程
    DECLARE
    BEGIN
    DBMS_OUTPUT.put_line(
    '在PL/SQL中打印的结果:'||stu_proc(1));
    END;

                 

    3、出参存储过程的调用

    --创建出参存储过程
    CREATE OR REPLACE FUNCTION stu_proc(v_name OUT VARCHAR2) RETURN VARCHAR2 IS
    BEGIN
    --执行语句段
    SELECT o.sname INTO v_name FROM student o where o.id=2;
    RETURN v_name;
    END;

    --调用出参存储过程
    DECLARE
    v_name student.sname
    %type;
    BEGIN
    DBMS_OUTPUT.put_line(
    '在PL/SQL中打印的结果:'||stu_proc(v_name));
    END;

                  

    4、出入参存储过程的调用

    --创建出入参存储过程
    CREATE OR REPLACE FUNCTION stu_proc(v_id IN NUMBER, v_name OUT VARCHAR2) RETURN VARCHAR2 IS
    BEGIN
    --执行语句段
    SELECT o.sname INTO v_name FROM student o where o.id=v_id;
    RETURN v_name;
    END;

    --调用出入参存储过程
    DECLARE
    v_name
    VARCHAR2(20);
    BEGIN
    DBMS_OUTPUT.put_line(
    '在PL/SQL中打印的结果:'||stu_proc(1, v_name));
    END;
  • 相关阅读:
    .net SMTP发送Email 更新(可带附件)
    Ext JS4百强应用: 做可编辑的,可checked的treegrid--第11强
    使你更有思想的20本书
    Sencha Architect 2 的使用
    Test SRM Level One: TemperatureScales
    Test SRM Level Two: CountExpressions, Brute Force
    JPDA 利用Eclipse和Tomcat进行远程调试 --转
    非对称加密算法RSA--转
    java/php/c#版rsa签名以及java验签实现--转
    JAVA/PHP/C#版RSA验签--转
  • 原文地址:https://www.cnblogs.com/linjiqin/p/2018847.html
Copyright © 2011-2022 走看看