千家信息网

oracle中游标,数组的使用

发表于:2025-02-22 作者:千家信息网编辑
千家信息网最后更新 2025年02月22日,1) select * from cnbs_security_role_menu for update;2)oracle 中游标的使用: http://www.cnblogs.com/sc-xx/ar
千家信息网最后更新 2025年02月22日oracle中游标,数组的使用

1) select * from cnbs_security_role_menu for update;


2)oracle 中游标的使用: http://www.cnblogs.com/sc-xx/archive/2011/12/03/2275084.html

declare

--类型定义

cursor c_job is

select combine_no,plan_code,flag from rate_combine where plan_code='C01' and rownum <10;

--定义一个游标变量

c_row c_job%rowtype;

begin

open c_job;

loop

--提取一行数据到c_row

fetch c_job into c_row;

--判读是否提取到值,没取到值就退出

--取到值c_job%notfound 是false

--取不到值c_job%notfound 是true

exit when c_job%notfound;

dbms_output.put_line(c_row.combine_no||'-'||c_row.plan_code||'-'||c_row.flag);

end loop;

--关闭游标

close c_job;

end;



3)如果使用固定长度的数组,而且不需要在外部定义可以如下定义

declare

type ar is varray(15) of varchar2(12); --声明数组类型

rt ar:=ar('dd','ff','ss'); --声明数组类型变量rt,并赋初值

i integer:=1;

begin

for i in 1..rt.count loop

-- rt(i):=i;

dbms_output.put_line('count='||rt(i));

end loop;

end;


4 )如果我们要使用的数组长度不能预计,我们可以按如下方法作:

declare

TYPE numtab IS TABLE OF varchar2(50) INDEX BY BINARY_INTEGER; //定义一个数组类型;

arr numtab; //使用这个类型声明一个变量;

i integer:=1;

begin

for i in 1..100 loop

arr(i):=i;//为变量赋值

dbms_output.put_line('arr['||i||']='||arr(i));

end loop;

dbms_output.put_line('count='||arr.count);

end ;


5)--- 使用带参数的游标;

declare

CURSOR stock_cur(symbol_in VARCHAR2) IS

SELECT * FROM rate_combine_nr nr WHERE nr.combine_no=symbol_in;

stock_info stock_cur%ROWTYPE;

begin

OPEN stock_cur('G600000001'); --打开游标;

loop

FETCH stock_cur INTO stock_info; --从游标中取值

exit when stock_cur%notfound;

dbms_output.put_line(stock_info.combine_no||'-'||stock_info.department_code);

end loop;

close stock_cur; --关闭游标

end;


0