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;

版权声明:本文为shaohz2014原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/shaohz2014/p/3713408.html