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;
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。