使用隐式游标属性

游标是一个独立SQL工作区,有两种性质的游标:

显式游标:是由程序员显式声明的。

隐式游标:

不用明确建立游标变量,分两种:

1. 在PL/SQL中使用DML语言,使用ORACLE提供的名为SQL的隐示游标

2. CURSOR FOR LOOP,用于for loop 语句。

 

例一:

declare
begin
 update departments set department_name=department_name
 where 1=2;
 dbms_output.put_line(‘update ‘|| sql%rowcount ||’ records’);
end;
/


例二:

declare
begin
 for my_dept_rec in ( select department_name, department_id from departments)
 loop
     dbms_output.put_line(my_dept_rec.department_id || ‘ : ’ || my_dept_rec.department_name);
 end loop;
end;
/


游标的属性:
SQL%ROWCOUNT:一个整数值,最近SQL语句影响的行数。当前时刻已经从游标中获取的记录数量。
SQL%FOUND:BOOLEAN属性,如果为TRUE,说明最近的SQL STATEMENT有返回值。
SQL%NOTFOUND:与SQL%FOUND相反
SQL%ISOPEN 在隐式游标中经常是FALSE,因为执行后立即自动关闭了。

 

 

如果想得到DML操作的记录数,则可以利用隐式游标属性... ...

 

 大家知道,显示游标有属性,但有时会想不起来隐式游标的属性:SQL%FUND、SQL%NOTFUND、SQL%ROWCOUNT。这三个属性的含义是:是否有记录,没有记录集,总处理的记录数。

 

  下面是一个例子,如何使用隐式游标。

 

create or replace procedure ptest(v_id number,v_lan in varchar2,v_name in varchar2) is
v_number number;
begin

 

update test set name=v_name,lastname=v_lan where id=v_id;
v_number:=sql%rowcount;
if v_number=0 then
insert into test(id,name,lastname) values(v_id,v_name,v_lan);
end if;
commit;
end;

 

      上例就是得用隐式游标进行对处理集的判断。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值