Oracle数据库学习10之游标

游标:是一种PL/SQL控制结构。
它可以命名一个工作区来存取该工作区的存储信息。游标就像一个指向结构集中当前记录的指针,通过游标可以处理结果集中的每一条记录。


1.游标的两种形式:隐式游标、显示游标


1.隐式游标:PL/SQL会隐式的为所有的DML SQL语句创建一个游标,包含那些只返回一条语句的查询。


2.显示游标:在声明部分显示的声明游标。PL/SQL不允许前向引用,在引用游标之前必须先声明
声明格式:cursor 游标名 [可选项] is select语句

1.关键字cursor用于声明一个游标。
2.可选项语法:
游标参数名  [in] 参数类型[{:=|default}]
由于PL/SQL不允许前向引用,所以一般声明游标都在最后,这样可以确保游标声明中被引用的变量都声明了。


2.游标的操作:open(打开)、fetch(提取)、close(关闭)


1.open:打开游标,通过打开游标操作来执行一个查询并得到一个结果集,该结果集由查询返回的全部记录组成。
格式:open 游标名;
注意:
1.若定义游标用来for update子句,则打开游标操作将锁定这些记录。
 当我们打开一个结果集后,所有对数据操作的语句对游标取出的结果集没有影响,直到游标关闭。
2.用open打开游标时,select语句有联编变量,则会对变量的取值进行检查,同时结果集被确定,游标指针指向结果集的第一行。
3.若游标有参数,可在open中来传递参数。除非缺省值,否则open语句滑总每一个形参都要有一个相应的实参。
4.打开一个已打开的游标时不会报错,会在打开之前隐式调用close关闭。可用%isopen判断游标是否已打开。
2.fetch:提取游标,从游标中提取数据。
格式:fetch 游标名 into vars_list
vars_list:是已被声明的和游标中提取的结果集类型相同或兼容的PL/SQL变量列表,或是和游标中提取的结果集类型相同或是兼容的已经被声明的PL/SQL记录类型。
注意:
1.游标的提取只能是向前的,若要提取前面的数据,要重新打开游标。
2.无法自动判断游标是否到结果集结尾,可用%found或notfound来判断游标是否到了结尾。
3.close:关闭游标,关闭游标之后所有和该游标有关的资源都会释放。
格式:close 游标名
注意:引用了一个关闭了的游标会发生错误,关闭一个已关闭的游标也会引发异常。


3.显示游标的属性:%isopen、%isfound、%isnofound、%rowcount


1.%found属性:
当一个游标或游标变量被打开且在执行fetch之前,%found为null。
最后的fetch语句返回一行记录,则%found为true,没有返回记录则为false。


2.%isopen属性:
当游标或游标变量被打开时,%isopen为true,否则为false。


3.%nofound:除了在执行fetch之前也为null,其他的与%found相反。


4.%rowcount:用来返回已经从游标中取出的记录条目。
在游标或游标变量被打开而没执行fetch之前,%rowcount为0,成功一次加1。


4.隐式游标:隐式游标同样有4属性。由于隐式游标没有名,所以用SQL表示隐式游标的名字。即:SQL%属性名
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值