您当前的位置: 首页 > 数据库教程 > Oracle教程 > oracle数据库中关于游标的常见用法

oracle数据库中关于游标的常见用法

作者:不详 来源:网络 发布时间: 2014-09-08 21:55 点击:
1、什么是游标 游标是一种PL/SQL控制结构,可以对SQL语句进行显示控制,便于对表的数据逐条进行处理 2、游标分类 显示游标: Declared and named by the programmer 隐式游标: Declared for all DML and PL/SQL SELECT statements 3、游标的属性: %FOUND:Evaluates to

oracle数据库中关于游标的常见用法

  1、什么是游标

  游标是一种PL/SQL控制结构,可以对SQL语句进行显示控制,便于对表的数据逐条进行处理

  2、游标分类

  显示游标: Declared and named by the programmer

  隐式游标: Declared for all DML and PL/SQL SELECT statements

  3、游标的属性:

  %FOUND:Evaluates to TRUE if the most recent SQL statement affects one or more rows

  %NOTFOUND:和%FOUND相反

  %ISOPEN:是一个布尔值,如果游标打开,则为TRUE, 如果游标关闭,则为FALSE.对于隐式游标而言SQL%ISOPEN总是FALSE,这是因为隐式游标在DML语句执行时打开,结束时就立即关闭。

  %ROWCOUNT:Number of records affected by the most recent SQL statement

  注意:dbms_output.put_line();这个是不能打印boolean型的,解决方法

  if b then

  dbms_output.put_line('b=true');

  end if;

  或者:

  declare

  b boolean;

  begin

  b := true;

  dbms_output.put_line((case when b then 'true' else 'false' end));

  end;

  对于null,课先使用NVL()或者decode()处理

  显示游标:需要手动open和close

  例如:

  DECLARE

  CURSOR mycursor IS

  SELECT * FROM dept;

  myrecord dept%ROWTYPE;

  BEGIN

  OPEN mycursor;

  FETCH mycursor INTO myrecord;

  WHILE mycursor%FOUND LOOP

  DBMS_OUTPUT.PUT_LINE(myrecord.deptno||' '||myrecord.dname||' '||myrecord.loc);

  FETCH mycursor INTO myrecord;

  END LOOP;

  CLOSE mycursor;

  END;

  注意:在进行while循环前,必须先有一个FETCH..INTO操作,否者%FOUND总是返 回false

  带参数的游标:

  DECLARE

  CURSOR mycursor(num varchar2) IS

  SELECT * FROM DEPT WHERE deptno=num;

  myrecord dept%ROWTYPE;

  BEGIN

  OPEN mycursor(10);

  LOOP

  FETCH mycursor INTO myrecord;

  EXIT WHEN mycursor%NOTFOUND;

  DBMS_OUTPUT.PUT_LINE('deptNum='||myrecord.deptno||' deptName='||myrecord.dname);

  END LOOP;

  CLOSE mycursor;

  END;

  FOR循环操作游标

  使用FOR循环读取游标时,不需要显示申明变量用于接收结果,也不需要手动打开和关闭游标,例如:

  DECLARE

  CURSOR mycursor(num varchar2) IS

  SELECT * FROM DEPT WHERE deptno=num;

  BEGIN

  FOR cur IN mycursor(10) LOOP

  DBMS_OUTPUT.PUT_LINE('deptNum='||cur.deptno||' deptName='||cur.dname);

  END LOOP;

  END;

  注意:PL/SQL中参数只需要给出类型,不需要给出长度或精度。

  当直接将游标的值读取到变量时,变量的个数应与游标指向的结果集的列数相同。例如结果集中有两个列,那么使用FETCH....INTO 时对应的变量个数也应该有两个。

  DECLARE

  d_no number;

  d_name varchar2(10);

  CURSOR mycursor(num varchar2) IS

  SELECT deptno,dname FROM DEPT WHERE deptno=num;

  BEGIN

  OPEN mycursor(10);

  FETCH mycursor INTO d_no,d_name;

  LOOP

  DBMS_OUTPUT.PUT_LINE(d_no||' '||d_name);

  FETCH mycursor INTO d_no,d_name;

  EXIT WHEN mycursor%NOTFOUND;

  END LOOP;

  CLOSE mycursor;

  END;

  /

  %ROWCOUNT初始值为null,每当使用FETCH...INTO从游标中取出一条数据后,    ROWCOUNT的值加1,并不是标识结果集的行数。

  例如:

  DECLARE

  d_name varchar2(10);

  CURSOR mycursor IS

  SELECT dname FROM DEPT;

  BEGIN

  OPEN mycursor;

  LOOP

  FETCH mycursor INTO d_name;

  EXIT WHEN mycursor%NOTFOUND;

  DBMS_OUTPUT.PUT_LINE(mycursor%ROWCOUNT);

  END LOOP;

  CLOSE mycursor;

  END;

  结果集中有4行记录,输出结果为:1 2 3 4

  可更新数据的游标

  要想在使用游标的同时修改数据,需要在申明游标时加上FOR UPDATE关键字。

  例如:

  DECLARE

  d_name VARCHAR2(20);

  CURSOR mycursor IS

  SELECT dname FROM dept FOR UPDATE;

  BEGIN

  OPEN mycursor;

  LOOP

  FETCH mycursor INTO d_name;

  EXIT WHEN mycursor%NOTFOUND;

  UPDATE dept SET dname=RTRIM(dname,'_t') WHERE CURRENT OF mycursor;

  END LOOP;

  CLOSE mycursor;

  END;

  CURRENT OF+游标名:获取游标当前所指向的行

  RTRIM(dname,'_t'):LTRIM、RTRIM实现字符串过滤(不仅仅去除空格)

  隐式游标:不使用DECLARE显示申明的游标。

  例如:

  BEGIN

  FOR cur IN(SELECT dname FROM dept) LOOP

  DBMS_OUTPUT.PUT_LINE(cur.dname);

  END LOOP;

  END;

  1、含有参数的游标

  declare

  cursor cur_my (mv number) is select * from Person where no<mv;

  begin

  for tem in cur_my(4) loop

  DBMS_OUTPUT.put_line('name:'||tem.name);

  end loop;

  end;

  2、设置引用游标

  declare

  temp_row Person%rowtype;

  type my_type is ref cursor;

  cur_my my_type;

  begin

  open cur_my for 'select * from Person ';

  loop

      fetch cur_my into temp_row;

      exit when cur_my%notfound;

      DBMS_OUTPUT.put_line('name:'||temp_row.name);

  end loop;

  close cur_my;

  end;

  3、for loop循环游标

  DECLARE

    v_id Integer;

    v_name varchar2(50);

    v_age Integer;

    cursor cur_mycursor is select id,name,age from Users;

  BEGIN

    for temp in cur_mycursor loop

       v_id :=temp.id;

       v_name :=temp.name;

       v_age :=temp.age;

       dbms_output.put_line('id:'||v_id||'name:'||v_name||'age:'||v_age);

    end loop;

    /**dbms_output.put_line('所有记录数:'||cur_mycursor%rowcount||'条!');*/

  END;

  4、标准化loop循环游标

  DECLARE

    v_id Integer;

    v_name varchar2(50);

    v_age Integer;

    cursor cur_mycursors is select id,name,age from Users;

  BEGIN

     OPEN cur_mycursors;

       dbms_output.put_line('所有记录数:'||cur_mycursors%rowcount||'条!');

     LOOP

       FETCH cur_mycursors INTO v_id,v_name,v_age;

       dbms_output.put_line('id:'||v_id||'name:'||v_name||'age:'||v_age);

       IF cur_mycursors%NOTFOUND THEN

            EXIT;

       END IF;

     END LOOP;

     dbms_output.put_line('所有记录数:'||cur_mycursors%rowcount||'条!');

     CLOSE cur_mycursors;

  END;
分享到:
本文"oracle数据库中关于游标的常见用法"由远航站长收集整理而来,仅供大家学习与参考使用。更多网站制作教程尽在远航站长站。
顶一下
(0)
0%
踩一下
(0)
0%
[点击 次] [返回上一页] [打印]
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 密码: 验证码:
关于本站 - 联系我们 - 广告合作 - 网站声明 - 友情连接- 网站地图 - 站点地图 - 返回顶部
Copyright © 2007-2013 www.yhzhan.com(远航站长). All Rights Reserved .
远航站长:为中小站长提供最佳的学习与交流平台,提供网页制作与网站编程等各类网站制作教程.
官方QQ:445490277 网站群:26680406 网站备案号:豫ICP备07500620号-4