隐式游标由PL/SQL自动定义、自动打开、自动关闭、不需要用户的参与。

隐式游标属性:

%FOUND,结果为BOOLEAN型,用于判断DML语句是否改变了行,或者判断SELECT INTO是否返回了一行或者多行数据。
%NOTFOUND,跟SQL%FOUND相反。
%ISOPEN,判断游标是否打开,对隐式游标来说,当SQL语句执行完成后,游标被自动关闭,因此SQL%ISOPEN的值永远是False
%ROWCOUNT,用于判断DML语句影响了多少行,或者SELECT INTO返回了多少行,结果为整形。

举例:

begin
	delete from tra;
	if sql%found then
		commit;
	else
		null;
	end if;
end;
SQL> begin
delete from tra;
dbms_output.put_line(to_char(sql%rowcount));
end;
/

显示游标

显示游标用cursor … is 命令定义
如:

declare
cursor ct is select * from ttc;
begin

打开游标

open ct;

关闭游标

close ct;

使用完游标之后,要关闭游标,未关闭的游标占用内存,耗费系统资源。如果数据库中存在很多未关闭的游标,还可能导致数据库死机。

从游标中取数据
使用fetch命令从游标中提取数据,每提取一次,游标都指向结果集的下一行。

显示游标的属性跟隐式游标属性意思不一样
%FOUND,结果为BOOLEAN型,当最后一次读记录成功,返回值为TRUE.
%NOTFOUND,跟%FOUND相反。
%ISOPEN,判断游标是否打开,当游标已打开时返回true
%ROWCOUNT,返回已从游标中读取的记录数(到目前为止),结果为整形。

举例:

declare
cursor c1 is select employee_id from t_bonus where bonus <500;
v_employee_id varchar2(20);
begin
	open c1;
	loop
		fetch c1 into v_employee_id;
		exit when c1%notfound or c1%notfound is null;
		-- .....
	end loop;
	--....
	close c1;
end;

游标变量

游标变量其实就是指针,这个指针可以指向不同的查询工作区。
游标变量的定义:

定义cursor类型的指针。

type ref_type_name is ref cursor [return return_type]

ref_type_name是新类型的名字,return_type是可选的,它必须是一个记录类型或行类型,我们称有返回类型的为“强ref cursor”,称没有返回类型的为“弱ref cursor”。
区别:弱ref cursor允许把游标变量与任何查询进行关联。
强ref cursor只允许把游标变量与特定查询进行关联。

强ref cursor

type strong_type is ref cursor return employees%rowtype;

弱ref cursor

type weak_type is ref cursor;

声明游标变量

strong_type v2

定义行类型:

v_rec employees%rowtype;-- 定义行类型