oracle 过程参数 out的调用问题。

2025-03-08 12:46:51
推荐回答(5个)
回答(1):

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.

回答(2):

在所定义的存储过程中,参数的名字后面加上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修饰。

回答(3):

oracle 存储过程out参数是存储过程会返还一个值给你,你在调用的时候需要设置个变量来接收存储过程返回给你的值吧。

回答(4):

MySQL教程4 MySQL8运算符、函数、存储过程及新增数据类型 17.之创建带有IN和OUT参数的存储过程 学习猿地

回答(5):

不可以