oracle存储过程游标使用疑问
createorreplaceprocedured_1istypemy_curisrefcursor;curmy_cur;beginforcurin(select*fro...
create or replace procedure d_1 is
type my_cur is ref cursor;
cur my_cur;
begin
for cur in (select * from t_t)
loop
dbms_output.put_line(cur.name);
exit when cur%notfound;
end loop;
CLOSE cur;
end;
为什么执行时会在
exit when cur%notfound;语句就报错,CLOSE cur;关闭游标也会报错,不太明白是什么原因,求指教
游标遍历数据有两种写法
方法二:
begin
open test_cursor for select ename,sal from emp where deptno=&no;
loop
fetch test_cursor into v_ename,v_sal;
exit when test_cursor%notfound;
dbms_output.put_line('名字:'||v_ename);
与之前一种方法有什么实质的区别么 展开
type my_cur is ref cursor;
cur my_cur;
begin
for cur in (select * from t_t)
loop
dbms_output.put_line(cur.name);
exit when cur%notfound;
end loop;
CLOSE cur;
end;
为什么执行时会在
exit when cur%notfound;语句就报错,CLOSE cur;关闭游标也会报错,不太明白是什么原因,求指教
游标遍历数据有两种写法
方法二:
begin
open test_cursor for select ename,sal from emp where deptno=&no;
loop
fetch test_cursor into v_ename,v_sal;
exit when test_cursor%notfound;
dbms_output.put_line('名字:'||v_ename);
与之前一种方法有什么实质的区别么 展开
2个回答
展开全部
1、for t_name in (select ...) loop
这个是隐式游标,相当于一个结果集,隐式Cursor由系统自动打开和关闭。
exit when %notfound是配合fetch使用,没有fetch就不需要。
你第一个存储过程可以这样写:
create or replace procedure d_1 is
begin
for cur in (select * from t_t) ---这个cur是隐式游标,无需定义,直接使用。
loop
dbms_output.put_line(cur.name);
end loop;
end;
/
2、使用的是标准的显式游标
a 定义游标---Cursor [Cursor Name] IS;
b 打开游标---Open [Cursor Name];
c 操作数据---Fetch [Cursor name]
d 关闭游标---Close [Cursor Name]
希望能帮到你。
这个是隐式游标,相当于一个结果集,隐式Cursor由系统自动打开和关闭。
exit when %notfound是配合fetch使用,没有fetch就不需要。
你第一个存储过程可以这样写:
create or replace procedure d_1 is
begin
for cur in (select * from t_t) ---这个cur是隐式游标,无需定义,直接使用。
loop
dbms_output.put_line(cur.name);
end loop;
end;
/
2、使用的是标准的显式游标
a 定义游标---Cursor [Cursor Name] IS;
b 打开游标---Open [Cursor Name];
c 操作数据---Fetch [Cursor name]
d 关闭游标---Close [Cursor Name]
希望能帮到你。
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询