专注收集记录技术开发学习笔记、技术难点、解决方案
网站信息搜索 >> 请输入关键词:
您当前的位置: 首页 > Oracle管理

oracle 中游标使用,调用fetch有关问题

发布时间:2010-05-20 14:01:29 文章来源:www.iduyao.cn 采编人员:星星草
oracle 中游标使用,调用fetch问题
本帖最后由 zhangrongchao_ 于 2014-12-11 17:10:51 编辑
为什么open 游标后,指针已经指向第一条数据了,接下来还要调用fetch 才能%found 判断为真?
执行以下查询语句 sqpplus的Scott模式下。


set serveroutput on
declare
  var_ename varchar2(50);--声明变量,用来存储雇员名称
  var_job varchar2(50);--声明变量,用来存储雇员的职务
  /*声明游标,检索指定员工编号的雇员信息*/  
  cursor cur_emp
  is select ename,job
    from emp
    where empno=7499;
begin
  open cur_emp;--打开游标
  fetch cur_emp into var_ename,var_job;--读取游标,并存储雇员名和职务
  if cur_emp%found then --若检索到数据记录,则输出雇员信息
    dbms_output.put_line('编号是7499的雇员名称为:'||var_ename||',职务是:'||var_job);
  else
    dbms_output.put_line('无数据记录');--提示无记录信息
  end if;
end;
/

输出:编号是7499的雇员名称为:ALLEN, 职务是:SALESMAN

我想问,查询结果只有一条,open cur_emp的时候指针已经指向结果集的第一条数据了(此例子中只有一条数据),
然后fetch cur_emp into var_ename,var_job; 把内容存入变量中,然后指针指向下一条数据,因为已经没有数据了,为什么判断语句中 cur_emp%found  为真呢?
------解决思路----------------------
open的时候不会读数据,FETCH才读。
1、说明游标。说明游标的时候并不执行select语句。
declare <游标名> cursor for <select语句>;
2、打开游标。打开游标实际上是执行相应的select语句,把查询结果读取到缓冲区中。这时候游标处于活动状态,指针指向查询结果集的第一条纪录。
 open <游标名>;
3、推进游标指针并读取当前纪录。用fetch语句把游标指针向前推进一条纪录,同时将缓冲区中的当前纪录读取出来送到变量中。fetch语句通常用在一个循环结构体中,通过循环执行fetch语句逐条取出结果集中的行进行处理。现在好多数据库中,还允许任意方向任意步长易懂游标指针,而不仅仅是把游标指针向前推进一行了。
 fetch <游标名> into <变量1>,<变量2>...
4、关闭游标。用close语句关闭游标,释放结果集占用的缓冲区及其他资源。游标关闭后,就不再和原来的查询结果集相联系。但游标可以再次打开,与新的查询结果相联系。
 close <游标名>;
------解决思路----------------------
cur_emp%found这个判断的是上次fetch是否取到数据,和当前指针没啥关系
友情提示:
信息收集于互联网,如果您发现错误或造成侵权,请及时通知本站更正或删除,具体联系方式见页面底部联系我们,谢谢。

其他相似内容:

热门推荐: