oracle怎么接收参数 oracle调用存储过程输出参数

oracle怎么调用带参数的存储过程

sqlplus或者PL/SQL SQL窗口输入(单独调用存储过程):无参数EXEC 过程名;或者BEGIN过程名END; IN 参数EXEC 过程名(入参数..);或者BEGIN过程名(入参数...)END; OUT参数,IN OUT参数variable 绑定变量名 数据类型; //定义一个变量接收出参数的值;EXEC 过程名(:绑定变量名);

创新互联建站公司2013年成立,先为灵台等服务建站,灵台等地企业,进行企业商务咨询服务。为灵台企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。

ORACLE中如何为存储过程传递参数?

第一种:只读。参数是只读的,不能修改,即调用时传递进来的是常量,或者变量(但变量不能在存储过程中修改)。通常select及DML类型的存储过程传递的是in类型的参数。

第二种:只写。忽略调用语句传递的任何参数,并在函数(过程)内部给这些参数赋值,因此是只写的。(这种情况是在函数或过程内部给参数重新赋值,但重新赋值后的参数是无法被外部调用的(好像游标类型的参数除外))

CREATE OR REPLACE  PROCEDURE "SCOTT"."SWAP" (firstValue out

number, secondValue out  number) is

temp number;

begin

temp := firstValue;

firstValue := secondValue;

secondValue := temp;

end swap;

外部调用:

set serveroutput on;

declare

firstVal number;

secondVal number;

begin

firstVal := 10;

secondVal := 20;

scott.swap(firstVal,secondVal);

dbms_output.put_line('first is ' || firstVal);

dbms_output.put_line('second is ' || secondVal);

end;

无法在外部访问到firstValue与secondValue的值。此时打印出的结果为:

first is

second is

第三种:读或写。这可以完全控制参数,读取传递的参数的值。可以再函数(过程)内部修改参数的值,在退出函数(过程)后,这些参数被赋给在函数内部写入的值,这样就可以返回多个值。(即入口参数写入值后,可以传递到函数(过程)的外部,供外部调用的时候使用)

ps:函数中的返回值为如下几种:

char;  varchar2; number; integer; date; boolean; table; record

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.

ORACLE中如何为存储过程传递参数

给你一个 传递参数的例子

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


名称栏目:oracle怎么接收参数 oracle调用存储过程输出参数
文章路径:http://myzitong.com/article/hgejcs.html