Oracle显示游标的使用详解

Oracle显示游标就是在声明单元明确定义的SELECT子句,并同时指定一个名字通过这个名字规范化地引用游标属性,同时在OPEN,FETCH,C

oracle显示游标就是在声明单元明确定义的select子句,并同时指定一个名字
通过这个名字规范化地引用游标属性,同时在open,fetch,close语句中通过名字来引用显示游标
insert,update,delete或者merge都没有显示游标这一说     

      ㈠ 声明显示游标

      语法:
      CURSOR cursor_name [ ( [parameter [,parameter…] ) ]  [RETURN return_specification]
      IS
        SELECT_statement
      这里Think建议,大家把游标放在包中定义
      这是一处声明,到处使用的方式
      以后要改善维护这个查询也就变得更加容易,而且能最小化查询语句的解析次数,同样可从性能上获益
      不过千万注意,在包级别定义,游标的生命是持续于整个会话范围
      这也意味着一个包级别的游标会一直保持打开状态,除非我们显示关闭该游标或者杀掉session
      下面对可选部分的参数列表和RETURN作详尽说明
     
      ⑴ 为什么要使用RETURN这个语句呢?
      首先,使用RETURN语句,实际上相当于公开声明了每次FETCH操作会返回的数据结构
      也就是,游标返回什么样的记录,返回的顺序是什么,都包含了哪些列等这些信息都已大白天下
      这就带来一个巧妙的地方,即我们可以把游标头和游标体分隔开来,比如:
      PACKAGE emp_info
      IS
        CURSOR emp_cur (name_in IN emp.name%TYPE) RETURN emp%ROWTYPE;
      END;
     
      PACKAGE BODY emp_info
      IS
        CURSOR emp_cur (name_in IN emp.name%TYPE) RETURN emp%ROWTYPE
        IS
          SELECT * FROM EMP WHERE name LIKE name_in;
      END;
      显然,包体的游标实际上是个黑盒子
      这带来两点好处:
      –隐藏信息,包体如何实现就可以变得非常神秘
      –最小化重编译,我们可以按需求的变化修改包体内游标的实现而不会影响到包头的游标规范
        这也意味着所有依赖于这个包的程序都不会被置成无效状态,自然也无须重编译
      游标的RETURN语句,可以由下面任意一种数据类型组成:
      ▲ table_name%ROWTYPE:基于某个数据库表定义的记录类型
      ▲ cursor_name%ROWTYPE:基于某个已经定义好的游标定义的记录类型
      ▲ record_type%ROWTYPE:基于程序员自定义的记录类型
      这里还有一个需要注意的是,SELECT 列表和RETURN的返回记录,他俩:
      –列的数量要相匹配
      –记录的数据类型也须要相互匹配
     
      ⑵ 啥时需要把我们的游标参数化呢?
      如果我们要在多个地方使用一个游标,每次只是WHERE子句的值不同,我就可以创建一个带参的游标,,比如:
      DECLARE
        CURSOR cursor_name (par_in IN VARCHAR2)
        IS
          SELECT emp_id,emp_name FROM emps
            WHERE emp_name=UPPER(par_in);
      游标中最常见的会使用参数的地方就是WHERE子句,不过也可以在SELECT语句中的任何地方使用参数,比如:
      DECLARE
        CURSOR cursor_name (par_in IN VARCHAR2)
        IS
          SELECT emp_name,par_in,job FROM emps
            WHERE emp_name=UPPER(par_in);
      游标参数的作用范围受限于游标,我们无法在游标关联的SELECT语句之外引用游标参数,如,执行单元处引用则无法编译通过
      游标参数只能是一个IN型参数,游标是不能通过参数列表把值传出去的
      游标参数化大抵有两个好处:
      ① 避免WHERE过滤条件是硬编码,让游标更好的重用
      ② 避免游标作用范围的问题,我们可在外层块定义游标,然后在内层块用局部变量调用这个游标
     
      ㈡ 打开显示游标
     
      语法:
      OPEN cursor_name [ ( parameter [,parameter…] ) ];
      Think认为,这里最重要的是关注Oracle的读一致性
      当我们打开一个游标时,PL/SQL会执行这个游标的查询语句,并标识出活跃数据集–符合WHERE过滤的记录
      但是OPEN不会真正提取出任何一行数据,这个动作是由FETCH来完成
      然而,无论我们什么时候开始第一次FETCH数据,Oracle都会保证所有的FETCH反映的都是游标打开那一刻的数据状态
      也就是,从打开游标的那一刻直到游标关闭的那一刻,通过游标获取的数据会自动忽略掉游标打开以后
      其他活动会话所进行的插入、更新、删除等操作
      如果我们使用FOR UPDATE子句,所有的活跃数据集在游标打开那时刻都会被锁定
      这就是Oracle的读一致性
      Oracle利用SCN来实现这个理论,开始查询时,会确定一个SELECT SCN,这样就保证了事务槽里所有的SCN都小于SELECT SCN

linux

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/1903575.html

(0)
上一篇 2025年2月22日 15:21:52
下一篇 2025年2月22日 15:22:39

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • Oracle 函数中游标及递归的应用

    在代码中使用递归可能大部分程序员都不陌生,但是在存储过程或者函数中写个递归估计就不多见了。今天遇到了一个在Oracle函数中使 在代码中使用递归可能大部分程序员都不陌生,但是在存储过程或者函数中写个递归估计就不多见了。 今天遇到了一个在Or…

    数据库 2025年2月23日
    300
  • Oracle中用游标更新字段值的面试题

    如下表 SQLgt; set pagesize 60; SQLgt; run; 1* select * from employee NAME SALARY ———- – 如下表 在这个表如果S…

    数据库 2025年2月22日
    200
  • Oracle数据库游标

    游标是SQL的一个内存工作区,由系统或用户以变量形式定义。游标的作用是用于临时存储从数据库中提取的数据块。为什么要用游标?数 游标的概念 游标是SQL的一个内存工作区,由系统或用户以变量形式定义。 游标的作用是用于临时存储从数据库中提取的数…

    数据库 2025年2月22日
    200
  • Oracle高级显式游标的使用

    多次打开相同的游标,返回不同的结果集。游标声明部分的形参必须与OPEN语句中提供的实参相对应(数量与数据类型)。 1、参数化的游标作用:多次打开相同的游标,返回不同的结果集。游标声明部分的形参必须与open语句中提供的实参相对应(数量与数据…

    数据库 2025年2月22日
    200
  • Oracle数据库中游标的使用

    游标的定义: 游标的作用 在前面的文章中有提到过,查询结果如果超过一行,就需要使用游标。在文章rdquo;Oracle数据中的PL/SQL介 游标的定义: 游标的作用 在前面的文章中有提到过,查询结果如果超过一行,就需要使用游标。在文章”O…

    数据库 2025年2月22日
    300
  • Oracle 自适应游标共享–adaptive cursor sharing

    在11g中,Oracle引入了一项新特征:adaptive cursor sharing 自适应游标共享。这项特征主要用来改进具有绑定变量的sql语句的执行 在11g中,oracle引入了一项新特征:adaptive cursor shar…

    数据库 2025年2月22日
    200

发表回复

登录后才能评论