`
kb5706
  • 浏览: 41500 次
  • 性别: Icon_minigender_1
  • 来自: 大连
文章分类
社区版块
存档分类
最新评论

从概念到示例—Oracle隐式游标

 
阅读更多

转载自 http://www.poluoluo.com/jzxy/201106/135219.html


一、游标的相关概念:

  定义:

   游标它是一个服务器端的存储区,这个区域提供给用户使用,在这个区域里

  存储的是用户通过一个查询语句得到的结果集,用户通过控制这个游标区域当中

  的指针 来提取游标中的数据,然后来进行操作。

  实质:

   是用户在远程客户端上对服务器内存区域的操作,由数据库为用户提供这样的

  一个指针,使得用户能够去检索服务器内存区的数据。

   (1)、 指向上下文区域的句柄或指针

   (2)、上下文区域-用于SQL处理的内存区

   (3)、上下文区域的内容

   - 语句处理的行数

   -指向语句的语法分析表示的指针

   二、游标的类型

   a)静态游标

   -  隐式游标

   -  显式游标

   b)Ref游标

   三、游标具有的属性

   %notfound 询问是否没有结果集

   %found    询问是否存在结果集

   %rowcount 返回受影响的行数

   %isopen   询问游标是否已经打开

   四、先来说说隐式游标

   隐式游标 ---由Oracle数据库自动创建,名称是(SQL) ,主要用途是可以返回一个操作是否成功或失败.

   1.有Oracle在内部声明,由系统管理

   2.用于处理

   -DML语句   --注意只能用于DML语句哦。

   -返回单行的查询

   3.用于判断一个操作是否成功.

   SQL%notfound  --返回Boolean值  存在结果集返回 False

   SQL%found    --返回Boolean值   存在结果集返回 True

   SQL%rowcount  --用户成功提取数据的行数

   SQL%isopen   --在隐式游标里一般这个属性是自动打开和关闭的.且任何时候查询都返回False

  示例:向表中插入一行数据,询问是否插入成功.

 

declare
   isCount int:=0;
 begin
    insert into place values(2,'beijing');
    DBMS_output.put_line('游标所影响的行数:'||SQL%rowcount);
    if SQL%NotFound then
      DBMS_output.put_line('NotFound为真);
    else
      DBMS_output.put_line('NofFound为假');
    end if;
  
     if SQL%Found then
      DBMS_output.put_line('Found为真);
     else
      DBMS_output.put_line('Found为假');
     end if;
      if SQL%isopen then
      DBMS_output.put_line('isOpen为真);
     else
      DBMS_output.put_line('isOpen为假');
     end if;
     
    isCount:=SQL%rowcount;
    DBMS_output.put_line('影响了'||isCount||'行');
  end;

分享到:
评论

相关推荐

    oracle 示例代码

    包括触发器、序列、游标参数 游标、转出过程参数、游标的rowcount用法 用游标修改数据 用for使用游标、视图、存储过程、隐式游标、过程等

    Oracle11g从入门到精通2

    《Oracle11g从入门到精通》面向数据库管理人员和数据库开发人员,从实际角度出发,系统地介绍了数据库和Oracle的相关概念和原理、Oracle的数据库管理(如安装与启动,用户权限、备份与恢复等),以及Oracle的应用...

    Oracle数据库原理及应用教学大纲.pdf

    * 游标的类型:隐式游标、显式游标 * 游标的优化技术 ### 14. 第十四讲:存储过程和函数 * 存储过程和函数的概念和使用 * 存储过程和函数的优点和缺点 * 存储过程和函数的应用场景 本教学大纲涵盖了 Oracle ...

    Oracle11g从入门到精通

    《Oracle11g从入门到精通》面向数据库管理人员和数据库开发人员,从实际角度出发,系统地介绍了数据库和Oracle的相关概念和原理、Oracle的数据库管理(如安装与启动,用户权限、备份与恢复等),以及Oracle的应用...

    ORACLE11G宝典.rar 是光盘里面的内容,书太厚咧没法影印啊

     《Oracle11g宝典》以Oracle提供的示例数据库为背景,从基本原理、理论提高、实际操作、经验策略、应用开发等方面,结合命令行方式、开发工具的使用、管理工具的使用、Oracle与Windows之间的关系等知识点,按照学习...

    PL/SQL 基础.doc

    /* 范围中间用2个点表示 从 low_blound 到 high_bound */ ... (循环体) END LOOP; 例: FOR v_cnt IN 1..5 LOOP SELECT * INTO v_emp FROM s_emp WHERE id = v_cnt; 注:a. 加上REVERSE关键字 表示递减,从...

    Oracle 10g 开发与管理

    3.另一种隐式游标 64 (二)显示游标 64 1.声明 64 2.打开和关闭 65 3.检索数据 65 (三)游标For循环 65 (四)游标变量 (动态游标) 66 1.定义 66 2.声明游标变量 66 3.打开游标变量 66 (五) 使用游标更新数据库 66 ...

    精通sql结构化查询语句

    以SQL Server为工具,讲解SQL语言的应用,提供了近500个曲型应用,读者可以随查随用,深入讲解SQL语言的各种查询语句,详细介绍数据库设计及管理,详细讲解存储过程、解发器和游标等知识,讲解了SQL语言在高级语言中...

    Oracle9i的init.ora参数中文说明

    Oracle9i初始化参数中文说明 Blank_trimming: 说明: 如果值为TRUE, 即使源长度比目标长度 (SQL92 兼容) 更长, 也允许分配数据。 值范围: TRUE | FALSE 默认值: FALSE serializable: 说明: 确定查询是否获取表级...

    Sql语言学习全套-给力推荐

    创建和使用游标示例.sql 各种联接类型示范.sql 命名事务.sql 回滚存储点.sql 子查询.sql 存储过程.sql 完全下线.sql 寻找雇员上级.txt 所有下线的数和名字.sql 所有下线的数目和名字View.sql 数据完整性....

    mysql数据库的基本操作语法

    注意:alter modify不支持一次修改多个列,但是Oracle支持多列修改 但是MySQL可以通过多个modify的方式完成: alter table user modify tel varchar(15) default '02087654321' first, modify name varchar(20) ...

Global site tag (gtag.js) - Google Analytics