执行存储过程参数
过程结构
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调用等)