oracle执行存储过程参数,执行存储过程参数解决思路

执行存储过程参数

过程结构

CREATE OR REPLACE PROCEDURE   bi_vc_check_account_main_p (

is_file_info      IN     VARCHAR2,                                 --文件名

ios_buffer        IN     VARCHAR2,                             --输入输出串

ios_buf_len       IN     NUMBER,                             --输入输出长度

ion_ret_code      IN OUT NUMBER,

ios_note          IN OUT VARCHAR2,               --入:文件名,出:返回信息

is_first_record   IN OUT VARCHAR2                                  --首记录

)

想了解一下如何通过sql语句将各个值打印输出出来?对于IN的我了解如何传参,对于IN OUT的就不知道了?请高手指教,谢谢

我写的SQL,不对

declare

ion_ret_code        NUMBER(4);

ios_note            VARCHAR2(40);

is_first_record     VARCHAR2(40);

begin

bi_vc_check_account_main_p

(

'hb_20091025.dz',

'2007-10-01 09:30:10,J2307100109301000001,01058500130,TELE,100.0',

4000,

ion_ret_code,--我希望这个值传进去一个 2,请问如何传参?

ios_note,

is_first_record

);

dbms_output.put_line(ion_ret_code);

dbms_output.put_line(ios_note );

dbms_output.put_line(is_first_record);

end;

------解决思路----------------------

declare

ion_ret_code        NUMBER(4);

ios_note            VARCHAR2(40);

is_first_record     VARCHAR2(40);

begin

ion_ret_code:=2;--调用前赋值就行了

bi_vc_check_account_main_p

(

'hb_20091025.dz',

'2007-10-01 09:30:10,J2307100109301000001,01058500130,TELE,100.0',

4000,

ion_ret_code,

ios_note,

is_first_record

);

dbms_output.put_line(ion_ret_code);

dbms_output.put_line(ios_note );

dbms_output.put_line(is_first_record);

end;

------解决思路----------------------

引用:

重新编译一下这个procedure,注意如果是不同的用户,调用时加上存储过程的的属主用户名作为前缀

------解决思路----------------------

变量和OUTPUT参数定义要一致。

VARCHAR2(40) 肯定不能匹配 VARCHAR2 默认4000的长度。

------解决思路----------------------

楼主你只到IN和OUT类型的参数的话,IN OUT就是包含这两种含义的一种参数格式,表示即使传入参数又是你在你所调用的存储过程中处理后的返回参数。

------解决思路----------------------

1、IN模式:只读。在模块里面,实参的数值只能被引用:变量和OUTPUT参数定义要一致。

VARCHAR2(40) 肯定不能匹配 VARCHAR2 默认4000的长度。

------解决思路----------------------

DBMS_OUTPUT.PUT_LINE('======'

------解决思路----------------------

L_TEST_B_COUNT);

这样打印到你的控制台。

有关存储过程,看我写的博客,5分钟就能在项目上用了,包含里面各种知识点,你看看

Oracle技术_5分钟会用存储过程_存储过程简单实例(包含循环、条件、增改查、参数传入、变量赋值、java调用等)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值