oracle 过程参数 out的调用问题。
比如一个存储过程CreateorreplaceprocedureProc_getDepMaxSal(Depidoutinteger),我要调用这个存储过程,那我给他参数么...
比如一个存储过程Create or replace procedure Proc_getDepMaxSal(Depid out integer),我要调用这个存储过程,那我给他参数么?out不是作为输出么?那我比如getDepMaxSal(a)这个a的话值没有意义是么?那可以不传参数么?
展开
6个回答
展开全部
OUT 参数必须传入的, 下面是一个 OUT 与 IN OUT 参数使用的例子。
SQL>宏乎 CREATE OR REPLACE PROCEDURE HelloWorld2 (
2 p_user_name IN VARCHAR2,
3 p_out_val OUT VARCHAR2,
4 p_inout_val IN OUT VARCHAR2
5 ) AS
6 BEGIN
7 dbms_output.put_line('Hello ' || p_user_name || p_inout_val || '!');
8 p_out_val := 'A';
9 p_inout_val := 'B';
10 END HelloWorld2;
11 /
Procedure created.
SQL> DECLARE
2 p_outval VARCHAR2(10);
3 p_inoutval VARCHAR2(10) := '~Hi~';
4 BEGIN
5 HelloWorld2('Edward', p_outval, p_inoutval);
6
7 dbms_output.put_line('棚绝谈p_outval=' || p_outval);
8 dbms_output.put_line('p_inoutval='链碰 || p_inoutval);
9 END;
10 /
Hello Edward~Hi~!
p_outval=A
p_inoutval=B
PL/SQL procedure successfully completed.
SQL>宏乎 CREATE OR REPLACE PROCEDURE HelloWorld2 (
2 p_user_name IN VARCHAR2,
3 p_out_val OUT VARCHAR2,
4 p_inout_val IN OUT VARCHAR2
5 ) AS
6 BEGIN
7 dbms_output.put_line('Hello ' || p_user_name || p_inout_val || '!');
8 p_out_val := 'A';
9 p_inout_val := 'B';
10 END HelloWorld2;
11 /
Procedure created.
SQL> DECLARE
2 p_outval VARCHAR2(10);
3 p_inoutval VARCHAR2(10) := '~Hi~';
4 BEGIN
5 HelloWorld2('Edward', p_outval, p_inoutval);
6
7 dbms_output.put_line('棚绝谈p_outval=' || p_outval);
8 dbms_output.put_line('p_inoutval='链碰 || p_inoutval);
9 END;
10 /
Hello Edward~Hi~!
p_outval=A
p_inoutval=B
PL/SQL procedure successfully completed.
参考资料: http://hi.baidu.com/wangzhiqing999/blog/item/0991d3124070854420a4e9b4.html
展开全部
在所定义的存储过程中,参轿肆冲数的名字后面加上out即可。
例如:
create
or
replace
procedure
pr1(id
in
varchar2,
name
out
varchar2)
is
begin
select
table_name
into
name
from
table1
where
table_id
=
id;
end
pr1;
其中存储过程pr1有两个参数,id是输入参数,只能向该存储过程传入值,用in修饰。name是输出参数,只能返雹皮回该存闭歼储过程的赋与name的结果,用out修饰。
例如:
create
or
replace
procedure
pr1(id
in
varchar2,
name
out
varchar2)
is
begin
select
table_name
into
name
from
table1
where
table_id
=
id;
end
pr1;
其中存储过程pr1有两个参数,id是输入参数,只能向该存储过程传入值,用in修饰。name是输出参数,只能返雹皮回该存闭歼储过程的赋与name的结果,用out修饰。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
oracle 存储橡贺过吵坦程out参数是存梁碰派储过程会返还一个值给你,你在调用的时候需要设置个变量来接收存储过程返回给你的值吧。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
MySQL教程4 MySQL8运算符、函数、存储过雹睁程及新增数据类型源配岁 17.之卖塌创建带有IN和OUT参数的存储过程 学习猿地
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不可以
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询