如果存储过程的名字是issuccess
创新互联是一家集网站建设,永城企业网站建设,永城品牌网站建设,网站定制,永城网站建设报价,网络营销,网络优化,永城网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。
可以这样定义入参
issuccess(PRM_I
in
varchar2).
调用的时候就可以:
issuccess('123456789');
作为传入的值来处理。
如果需要把存储过程中处理的结果返回出来,那么可以定以OUT
参数:
issuccess(PRM_I
in
varchar2,PRM_O
OUT
VARCHAR).
调用之前准备一个变量
VS_OUT
varchar2(20);
调用时:
issuccess('123456789',VS_OUT).
过程里面修改PRM_O的值,过程执行完成后可以通过VS_OUT捕获。
1、创建测试表,
create table test_val(id varchar2(20),remark varchar2(20));
2、插入测试数据;
insert into test_val select level, 'lvl_'||level remark from dual connect by level=100;
commit;
3、编写语句,将表中的记录数赋值给变量;
declare
v_int number;
begin
execute immediate 'select count(*) from test_val' into v_int;
end;
4、将变量值打印,查看结果;
dbms_output.put_line(v_int);
cmd.Parameters.Add("变量1", 数据类型).Value = 值1;
这样ORACLE不会帮你把所有命名为"变量1”的绑定变量都赋值的。
假使语句为:
select * from A where b=:M and c=:M and d=:N 经过ORACLE解析后就成了 select * from A where b=:1 and c=:2 and d=:3
这样就需要给 绑定变量 1,2,3赋值。除非你在存储过程里面写。不然系统不会识别绑定变量名(就是个虚拟的而已)。
所以这种情况你需要
cmd.Parameters.Add("M", 数据类型).Value = 值1;
cmd.Parameters.Add("M", 数据类型).Value = 值1;
cmd.Parameters.Add("N", 数据类型).Value = 值2;
这样就不会报错。
有什么不理解的可以再问我。
oracle赋值语句如下:
declare
bb table1.a%rowtype;
begin
select a into bb from table1 where b='1';
--dbms_output.put_line(bb);
赋值语句用来表明赋给某一个变量一个具体的确定值的语句叫做赋值语句。在算法语句中,赋值语句是最基本的语句。赋值运算符左侧的编程元素必须能够接受和存储值。这意味着编程元素必须是一个不为ReadOnly(VisualBasic)的变量或属性,或者必须是一个数组元素。在赋值语句的上下文中,此类元素有时称为lvalue,即“leftvalue”(左侧的值)。