PL/SQL学习三

本文详细介绍了游标的使用方法,包括声明、打开、处理数据及关闭等步骤,并提供了使用loop、while及for循环遍历游标的示例代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

游标的使用:

n  作用

q  我们的select语句的结果集中只能有一条记录,这给程序带来了很大的限制,比如说,我们现在想把emp表中的每一条记录,按照一些复杂的逻辑取出来进行显示或更新,这个时候需要某种机制在表中的多条记录之间进行循环,这种机制就是游标。游标就是指在某个结果集上的指针,通过这个指针的移动,我们得以遍历整个结果集,这样我们就可以一次取出多条记录,然后按照程序的逻辑一条一条地进行处理。 

n  典型的游标使用的步骤包括以下几步:

q  声明游标

q  打开游标

q  处理游标中的数据

q  关闭游标

n  典型示例:

declare

        cursor c  is  select * from emp;

        v_emp c%rowtype;

begin

        open c;

fetch c into v_emp;

        dbms_output.put_line(v_emp.ename);

close c;

end;

 

n  最常用的游标属性有以下四个:

q  %isopenboolean类型变量,用来代表游标是否打开。

q  %notfoundboolean类型变量,如果最近的fetch语句没有返回一条记录,取true

q  %foundboolean类型变量,如果最近的fetch语句取到了记录,取true

q  %rowcountnumber类型变量,用来代表目前fetch到的记录的总行数。

q  loop循环遍历游标

n  While循环遍历游标

n  For循环遍历游标

n  带参数的游标

n  使用游标更新结果集

 

游标的简单使用:

declare

    cursor c is   select * from emp order by ename desc;

    v_emp c%rowtype;

begin

    open c;

    fetch c into v_emp;

    dbms_output.put_line(v_emp.ename);

    close c;

end;

利用loop循环和%notfound属性,我们可以实现游标的遍历,下面给出一个例子:

declare

   cursor c is

      select * from emp;

   v_emp emp%rowtype;

begin

   open c;

   loop

      fetch c into v_emp;

      exit when (c%notfound);

      dbms_output.put_line(v_emp.ename);

   end loop;

   close c;

end;

 

利用while循环配合%found属性,我们也可以遍历游标,例:

declare

   cursor c is

      select * from emp;

   v_emp emp%rowtype;

begin

   open c;

   fetch c into v_emp;

   while (c%found) loop

      dbms_output.put_line(v_emp.ename);

      fetch c into v_emp;

   end loop;

   close c;

end;

 

利用for循环遍历游标最简单,例如:

declare

   cursor c is

      select * from emp;

begin

   for v_emp in c loop

      dbms_output.put_line(v_emp.ename);

   end loop;

end;

 

这个时候,我们不需要打开游标,也不需要关闭,甚至不用声明循环变量v_emp,这一切都在for循环内部自动完成,正因为for循环处理游标是如此简单,因此大多数时候我们所使用的都是for循环。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值