oracle游标详解

隐式游标由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;

带参数的游标,参考 https://blog.csdn.net/huangbaokang/article/details/79570896

游标变量

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

定义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;-- 定义行类型
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

黄宝康

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值