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、⽆参数存储过程
CREATE OR REPLACE PROCEDURE 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、仅带⼊参的存储过程
CREATE OR REPLACE PROCEDURE 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函数调⽤中说明
CREATE OR REPLACE PROCEDURE stu_proc(v_name OUT student.sname%type) AS
--声明语句段
BEGIN
--执⾏语句段
SELECT o.sname INTO v_name FROM student o where o.id=1;
oracle手动调用存储过程dbms_output.put_line(v_name);
EXCEPTION
-
-异常处理语句段
WHEN NO_DATA_FOUND THEN dbms_output.put_line('NO_DATA_FOUND');
END;
4、带⼊参和出参的存储过程
--此种存储过程不能直接⽤call来调⽤,这种情况的调⽤将在下⾯oracle函数调⽤中说明
CREATE OR REPLACE PROCEDURE 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;