PL/SQL学习笔记四:游标的使用

游标概念

为了处理SQL语句,ORACLE必须分配一片叫上下文(context area)的区域来处理所必需的信息,其中包括要处理的行的数目,一个指向语句被分析以后的标识形式的指针以及查询的活动集(active set)。游标是一个指向上下文的句柄(handle)或指针。通过游标,PL/SQL可以控制上下文区域和处理语句时上下文区徽发生些什么事情。对于不同的SQL语句,由表的使用请款不同:非查询sql语句,游标为隐式的;结果是单行的sql查询语句,游标可以是隐式的也可以是显式的;结果是多行的sql查询语句,游标是显式的。

 

处理显式游标

处理显示游标需要的步骤:

    1、定义游标:就是定义一个游标名,以及与其相对应的SELECT语句。

           格式:CURSOR cursor_name[(parameter[,parameter]...)]IS select_statement;

                   游标参数只能为输入参数,其格式为:parameter_name[IN] datatype[{:=|DEFAULT} expression],在指定数据类型时,不能使用长度约束。

    2、打开游标:就是执行游标所对应的SELECT语句,将其查询结果放入工作区,并且指针指向工作区的首部,表示游标结果集合。如果游标查询语句中带有

                   FOR UPDATE选项,OPEN语句还将锁定数据库表中游标结果集合对应的数据行。

           格式:OPEN cursor_name[([parameter=>]value[,[parameter=>]value]...)];PL/SQL语句不能用OPEN语句重复打开一个游标。

    3、提取游标数据:就是检索结果稽核中的数据行,放入指定的输出变量中。

           格式:FETCH cursor_name INTO {variable_list | record_variable};

    4、对该记录进行处理;

    5、继续处理,直到活动集合中没有记录;

    6、关闭游标,当提取和处理完游标结果集合数据后,应及时关闭游标,以释放该游标所占用的系统资源,并使该游标的工作区变成无效,不能再使用FETCH语

               句取其中数据。关闭游标后可以使用OPEN语句重新打开。

           格式:CLOSE curson_name;

           注意:定义的游标不能有INTO子句。

    游标属性:

        1、%FOUND:布尔型属性,当最近一次读记录时成功返回,则值为TRUE;

        2、%NOTFOUND:布尔型属性,与%FOUND相反;

        3、%ISOPEN:布尔型属性,当游标已打开时返回TRUE;

        4、%ROWCOUNT:数字型属性,返回已从游标中读取的记录数。

    游标的FOR循环:

        PL/SQL语言提供了游标FOR循环语句,自动执行游标的OPEN、FETCH、CLOSE语句和循环语句的功能:当进入循环时,游标FOR循环语句自动打开游标,

    并提取第一行游标数据,当程序处理完当前所提取的数据而进入下一次循环时,由表FOR循环语句自动提取下一行数据供程序处理,当提取完结果集合众的所有

    数据行后结束循环,并自动关闭游标。

        格式:FOR index_variable IN cursor_name[value[, value]...] LOOP

                     -- 游标数据处理代码

                 END LOOP;

                 其中index_variable为游标FOR循环语句隐含声明的索引变量,该变量为记录变量,其结构与游标查询语句返回的结构集合的结构相同。在程序中可以

            通过引用该索引记录变量元素来读取所提取的游标数据,index_variable中各元素的名称与游标查询语句选择列表中所制定的列名相同。如果在游标查询

            语句的选择列表中存在计算列,则必须为这些计算列指定别名后才能通过游标FOR循环语句中的索引变量来访问这些列数据。

                 注意:不要在程序中对游标进行人工操作;不要在程序中定义用于控制FOR循环的记录。

 

处理隐式游标

    显式游标主要用于对查询语句的处理,尤其是在查询结果为多条记录的情况下;而对于非查询语句,如修改、删除操作,则由ORACLE系统自动地为这些操作设置游标并创建其工作区,这些由系统隐含创建的游标成为隐式游标,隐式游标的名字为SQL,这是由ORACLE系统定义的,对于隐式游标的操作,如定义、打开、取值及关闭操作,都由ORACLE系统自动地完成,无需用户进行处理。用户只能通过瘾式游标的相关属性,来完成相应的操作,在隐式游标的工作区中,所存放的数据是与用户自定义的显示游标无关的,最新处理的一条SQL语句所包含的数据。格式调用为:SQL%

    注意:INSERT, UPDATE, DELETE, SELECT语句中不必明确定义游标。

    隐式游标属性:

        1、SQL%FOUND:布尔型属性,当最近一次读记录时成功返回,则值为true;

        2、SQL%NOTFOUND:布尔型属性,与%FOUND相反;

        3、SQL%ROWCOUNT:数字型属性,返回已从游标中读取的记录数;

        4、SQL%ISOPEN:布尔型属性,取值总是FALSE,SQL命令执行完毕立即关闭隐式游标。

 

修改游标和删除操作

    游标修改和删除操作是指在游标定位下,修改或删除表中指定的数据行。这时,要求游标查询语句中必须使用FOR UPDATE选项,以便在打开游标时锁定游标结果集合在表中对应数据行的所有列和部分列。

    为了对正在处理(查询)的行不被另外的用户改动,ORACLE提供一个FOR UPDATE子句来对所选择的行进行锁定。该需求迫使ORACLE锁定游标结果集合的行,可以防止其他事务处理更新或删除相同的行,直到您的十五处理提交或回退为止。

    语法:SELECT ... FROM ... FOR UPDATE [OF column[, column]...][NOWAIT]

    如果另一个绘画已对活动集中的行加了锁,那么SELECT FOR UPDATE操作一直等待到其它的会话释放这些锁后才继续自己的操作,对于这种情况,当加上NOWAIT子句时,如果这些行镇的被另一个会话锁定,则OPEN立即返回并给出:ORA-0054:resource busy and acquire with nowait specified.

    如果使用FOR UPDATE声明游标,则可在DELETE和UPDATE语句中使用WHERE CURRENT OF cursor_name子句,修改或删除游标结果集合当前行对应的数据库表中的数据行。

转载于:https://www.cnblogs.com/flyingAngle/archive/2012/09/26/2704289.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值