oracle中游标的作用有哪些?什么情况下使用?

 我来答
HBITC3
推荐于2019-09-25 · TA获得超过7.5万个赞
知道小有建树答主
回答量:453
采纳率:100%
帮助的人:17.2万
展开全部

存储过程中查询语句如何返回多行结果?我们知道,如果存储过程中查询语句有多行结果输出,会报错。若想让存储过程中的查询语句返回多行结果不报错,则需要使用游标来实现。本例主要也是用来熟悉存储过程中游标的简单使用方法:

SET SERVEROUTPUT ON;

create or replace procedure proc_salary is

 

--定义变量
 

v_empno emp.empno%TYPE;

v_ename emp.ename%TYPE;
 

v_sal emp.sal%TYPE;  
 

--定义游标 

CURSOR emp_cursor IS  SELECT empno, ename, sal from emp;

BEGIN--循环开始

LOOP

 IF NOT emp_cursor%ISOPEN  THEN
   

OPEN emp_cursor;  END IF;
  

FETCH emp_cursor INTO  v_empno, v_ename, v_sal;

--退出循环的条件 

EXIT WHEN emp_cursor%NOTFOUND OR emp_cursor%NOTFOUND IS NULL;

dbms_output.put_line('员工编号为' || v_empno || '的' || v_ename || '薪水为:' || v_sal);   

END LOOP;END; 

/

匿名用户
2019-12-06
展开全部
游标(Cursor)是处理数据的一种方法,为了查看或者处理结果集中的数据,游标提供了在结果集中一次一行或者多行前进或向后浏览数据的能力。可以把游标当作一个指针,它可以指定结果中的任何位置,然后允许用户对指定位置的数据进行处理。游标实际上是一种能从包括多条数据记录的结果集中每次提取一条记录的机制。游标可以被看作是一个查询结果集(可以是零条、一条或由相关的选择语句检索出的多条记录)和结果集中指向特定记录的游标位置组成的一个临时文件,提供了在查询结果集中向前或向后浏览数据、处理结果集中数据的能力。有了游标,用户就可以访问结果集中任意一行数据,在将游标放置到某行之后,可以在该行或从该位置的行块上执行操作。其实就是用于存放查询出来的多条记录的一个临时变量,我们可以从这个变量中取出我们需要的信息字段。
--连接系统数据库
SQL>conn / as sysdba
--以下是在sql窗口下执行的
declare
--声明游标
Cursor cur_file is
select file#, status$,blocks from file$;
CurFileInfo cur_file%rowtype; --定义游标变量(所有的变量都在里面)
begin
open cur_file; --打开游标
Loop
Fetch cur_file into CurFileInfo ;
Exit when cur_file%notfound;--查不到数据则退出;
Dbms_Output.put_line(CurFileInfo.file#);
end loop;
Exception--出现异常,则关闭游标,并打印出问题来
when others then
close cur_file;
Dbms_Output.put_line(sqlerrm);
if cur_file%isopen then
--关闭游标
close cur_file;
end if;
end;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式