游标-----20161219

游标的概念

从数据表中提取出来的数据,以临时表的形式存放在内存中,在游标中有一个数据指针,在初始状态下指向的是首记录,利用fetch语句可以移动该指针,从而对游标中的数据进行各种操作,然后将操作结果写回数据表中。

游标的定义

cursor 游标名 is select语句;

游标的操作

打开游标
  open 游标名;
  游标提取数据时,每次只能提取一行,提取游标中的数据,使用fetch
  fetch 游标名 into 变量名1, 变量名2, ..........;或者
  fetch 游标名 into 记录型变量名;

游标的优点
  • 1、可从不同的select语句中提取结果集。
  • 2、可以作为过程的参数进行传递。
  • 3、可以引用游标的所有属性。
  • 4、可以进行赋值运算。
使用游标的限制
  • 1、不能在程序包中声明游标变量。
  • 2、for update子句不能与游标变量一起使用。
  • 3、不能使用比较运算符。
游标的分类
隐式游标

执行DML SQL语句时自动创建隐式游标,与显时游标不同,不被程序打开和关闭,属性有:
  1、%found -----> SQL语句影响了一行或多行时为true
  2、%notfound -----> SQL语句没有影响时为true
  3、%rowcount -----> SQL语句影响的行数
  4、%isopen -----> 游标是否打开,始终为false
例:

begin
  update toys set toyprice=270;
  where toyid='P005';
  if SQL%found then
    dbms_output.put_line( '表已更新.......' );
  end if;
end;  //返回true 当DML语句影响一行多或多行时,返回true```
######显式游标
  用于处理返回多行的查询,使用创建好的游标需要先打开游标,语法:
  ```open 游标名;```
  打开游标的过程有两个步骤:
  (1)将符合条件的记录送入内存。
  (2)将指针指向第一条记录。
  使用结束后要关闭游标,语法:
  ```close 游标名;```
  游标提取数据时,每次只能提取一行,提取游标中的数据,使用fetch 
  ```fetch 游标名 into 变量名1, 变量名2, ..........;```或者
  ```fetch 游标名 into 记录型变量名;```
  允许使用游标删除或更新活动集中的行,声明游标时必须使用:
  ```select ... for update ```
######REF游标
  用于处理运行时才能确定的动态 SQL 查询的结果。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,955评论 18 399
  • 1.1 基本结构 PL/SQL程序由三个块组成,即声明部分、执行部分、异常处理部分。 1.2 命名规则 1.3 记...
    慢清尘阅读 9,333评论 3 14
  • 测试: http://blog.csdn.net/chenmengyi828/article/details/52...
    Miley_MOJIE阅读 4,654评论 0 1
  • # 11The impact of regulations on the supply and quality o...
    Ordinary阅读 2,720评论 0 1
  • 昨天老公带着我们去金家坝吃麻辣烫,刚吃了一半,接了一个电话就走了。做这一行就是这样,客人永远都是上帝!就这样把我们...
    Buringsoul阅读 1,521评论 1 1