zoukankan      html  css  js  c++  java
  • Oracle 中 Cursor 介绍

    一  概念
    游标是SQL的一个内存工作区,由系统或用户以变量的形式定义。游标的作用就是用于临时存储从数据库中提取的数据块。在某些情况下,需要把数据从存放在磁盘的表中调到计算机内存中进行处理,最后将处理结果显示出来或最终写回数据库。这样数据处理的速度才会提高,否则频繁的磁盘数据交换会降低效率。
    二  类型
      Cursor类型包含三种: 隐式Cursor,显式Cursor和Ref Cursor(动态Cursor)。
    1. 隐式Cursor:
    1).对于Select …INTO…语句,一次只能从数据库中获取到一条数据,对于这种类型的DML Sql语句,就是隐式Cursor。例如:Select /Update / Insert/Delete操作。
    2)作用:可以通过隐式Cusor的属性来了解操作的状态和结果,从而达到流程的控制。Cursor的属性包含:
    SQL%ROWCOUNT 整型 代表DML语句成功执行的数据行数
    SQL%FOUND  布尔型  值为TRUE代表插入、删除、更新或单行查询操作成功
    SQL%NOTFOUND 布尔型 与SQL%FOUND属性返回值相反
    SQL%ISOPEN 布尔型 DML执行过程中为真,结束后为假
    3) 隐式Cursor是系统自动打开和关闭Cursor.
    下面是一个Sample:
    Sql代码 
    在PL/SQL中run:
    Sql代码 
    2. 显式Cursor:
    (1) 对于从数据库中提取多行数据,就需要使用显式Cursor。显式Cursor的属性包含:
    游标的属性   返回值类型   意    义 
    %ROWCOUNT   整型  获得FETCH语句返回的数据行数 
    %FOUND  布尔型 最近的FETCH语句返回一行数据则为真,否则为假 
    %NOTFOUND   布尔型 与%FOUND属性返回值相反 
    %ISOPEN 布尔型 游标已经打开时值为真,否则为假 

    (2) 对于显式游标的运用分为四个步骤:
     定义游标---Cursor  [Cursor Name]  IS;
     打开游标---Open  [Cursor Name];
     操作数据---Fetch  [Cursor name]
     关闭游标---Close [Cursor Name],这个Step绝对不可以遗漏。
    (3)以下是三种常见显式Cursor用法。
    1)
    Sql代码 

    2)
    Sql代码 

     



    3)Sql代码
     
    run pl/sql,执行结果如下:
     

    3. Ref Cursor(动态游标):
    1) 与隐式Cursor,显式Cursor的区别:Ref Cursor是可以通过在运行期间传递参数来获取数据结果集。而另外两种Cursor,是静态的,在编译期间就决定数据结果集。
    2) Ref cursor的使用:
     Type [Cursor type name] is ref cursor
     Define 动态的Sql语句
     Open cursor
     操作数据---Fetch  [Cursor name]
     Close Cursor
    下面是一个Sample:
     

    4.常见Exception
    Sql代码 

  • 相关阅读:
    unexpected inconsistency;run fsck manually esxi断电后虚拟机启动故障
    centos 安装mysql 5.7
    centos 7 卸载mysql
    centos7 在线安装mysql5.6,客户端远程连接mysql
    ubuntu 14.04配置ip和dns
    centos7 上搭建mqtt服务
    windows eclipse IDE打开当前类所在文件路径
    git 在非空文件夹clone新项目
    eclipse中java build path下 allow output folders for source folders 无法勾选,该如何解决 eclipse中java build path下 allow output folders for source folders 无法勾选,
    Eclipse Kepler中配置JadClipse
  • 原文地址:https://www.cnblogs.com/pekkle/p/6568811.html
Copyright © 2011-2022 走看看