oracle 游标的使用


-- 游标的使用
 %found:       检验是否fetch到值
 %notfound:  判断游标所在的行是否有效
 %rowcount:  成功执行的数据行数
 %isopen:      判断游标是否打开
-- for...loop(不需要显式打开、取值、关闭游标)
CREATE OR REPLACE procedure get_emp_info_p as
  -- 声明一个游标
  cursor empcur is select * from emp;
  empinfo emp%rowtype;
begin
  -- 循环
  for empinfo in empcur loop
    exit when empcur%notfound;
    dbms_output.put_line('员工编号:'||empinfo.empno);
    dbms_output.put_line('员工姓名:'||empinfo.ename);
  end loop;
end;
------------------------------------------------------
-- while...loop(需要显式打开、取值、关闭游标)
CREATE OR REPLACE procedure get_emp_info_p as
  -- 声明一个游标
  cursor empcur is select * from emp;
  empinfo emp%rowtype;
begin
  -- 对游标的操作使用循环,操作之前必须先打开游标
  -- 判断游标是否已经打开
  if empcur%isopen then
    null;
  else
    open empcur;
  end if;
  -- 提取数据
  fetch empcur into empinfo;
  -- 判断此行是否有数据,有就进入循环体
  while (empcur%found) loop
    dbms_output.put_line('员工编号:'||empinfo.empno);
    dbms_output.put_line('员工姓名:'||empinfo.ename);
    -- 修改游标,继续向下提取数据
    fetch empcur into empinfo;
  end loop;
  close empcur;
end;
------------------------------------------------------
-- loop...when(需要显式打开、取值、关闭游标)
CREATE OR REPLACE procedure get_emp_info_p as
  -- 声明一个游标
  cursor empcur is select * from emp;
  empinfo emp%rowtype;
begin
  -- 对游标的操作使用循环,操作之前必须先打开游标
  -- 判断游标是否已经打开
  if empcur%isopen then
    null;
  else
    open empcur;
  end if;
  -- 循环
  loop
    -- 提取数据
    fetch empcur into empinfo;
    -- 没有数据的时候就exit
    exit when empcur% notfound;
    dbms_output.put_line('员工编号:'||empinfo.empno);
    dbms_output.put_line('员工姓名:'||empinfo.ename);
  end loop;
end;


-- 执行存储过程

exec get_emp_info_p;

 

结果:



 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值