oracle中调用存储过程时传递参数值的3种方式。。

2025-01-23 00:02:51
推荐回答(4个)
回答(1):

应该就是这三种吧。
1 , IN (参数值传过来给存储过程使用)
2, OUT(存储过程返回结果给该参数)
3. IN OUT(存储过程调用该参数的同时,最后还返回结果给调用的参数)

回答(2):

拿scott下emp表来说吧
1直接赋值
v_ename emp.emame%type:=’aaa‘;
2通过select into 赋值
declare
v_ename emp.ename%type;
begin
select ename into v_ename from emp;
3从键盘输入
declare
v_ename emp.ename%type;
begin
v_ename:=&请输入员工姓名;

回答(3):

IN、OUT、IN OUT
这3种方式么?

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.

回答(4):

不明白?
你是指 IN OUT么?