日期:2014-05-16  浏览次数:20483 次

oracle隐式游标,显示游标,游标循环

游标的概念:
??? 游标是SQL的一个内存工作区,由系统或用户以变量的形式定义。游标的作用就是用于临时存储从数据库中提取的数据块。在某些情况下,需要把数据从存放在磁盘的表中调到计算机内存中进行处理,最后将处理结果显示出来或最终写回数据库。这样数据处理的速度才会提高,否则频繁的磁盘数据交换会降低效率。
游标有两种类型:显式游标和隐式游标。在前述程序中用到的SELECT...INTO...查询语句,一次只能从数据库中提取一行数据,对于这种形式的查询和DML操作,系统都会使用一个隐式游标。但是如果要提取多行数据,就要由程序员定义一个显式游标,并通过与游标有关的语句进行处理。显式游标对应一个返回结果为多行多列的SELECT语句。
游标一旦打开,数据就从数据库中传送到游标变量中,然后应用程序再从游标变量中分解出需要的数据,并进行处理。
隐式游标
如前所述,DML操作和单行SELECT语句会使用隐式游标,它们是:
* 插入操作:INSERT。
* 更新操作:UPDATE。
* 删除操作:DELETE。
* 单行查询操作:SELECT ... INTO ...。
当系统使用一个隐式游标时,可以通过隐式游标的属性来了解操作的状态和结果,进而控制程序的流程。隐式游标可以使用名字SQL来访问,但要注意,通过SQL游标名总是只能访问前一个DML操作或单行SELECT操作的游标属性。所以通常在刚刚执行完操作之后,立即使用SQL游标名来访问属性。游标的属性有四种,如下所示。

Sql代码 复制代码
  1. 隐式游标的属性?返回值类型???意????义 ??
  2. SQL%ROWCOUNT????整型??代表DML语句成功执行的数据行数 ??
  3. SQL%FOUND???布尔型?值为TRUE代表插入、删除、更新或单行查询操作成功 ??
  4. SQL%NOTFOUND????布尔型?与SQL%FOUND属性返回值相反 ??
  5. SQL%ISOPEN??布尔型?DML执行过程中为真,结束后为假??
隐式游标的属性	返回值类型	意    义
SQL%ROWCOUNT	整型	代表DML语句成功执行的数据行数
SQL%FOUND	布尔型	值为TRUE代表插入、删除、更新或单行查询操作成功
SQL%NOTFOUND	布尔型	与SQL%FOUND属性返回值相反
SQL%ISOPEN	布尔型	DML执行过程中为真,结束后为假


【训练1】 使用隐式游标的属性,判断对雇员工资的修改是否成功。
步骤1:输入和运行以下程序:

Sql代码 复制代码
  1. SET?SERVEROUTPUT?ON? ??
  2. ????????BEGIN??
  3. ????????UPDATE?emp?SET?sal=sal+100?WHERE?empno=1234; ??
  4. ?????????IF?SQL%FOUND?THEN? ??
  5. ????????DBMS_OUTPUT.PUT_LINE('成功修改雇员工资!'); ??
  6. ????????COMMIT;? ??
  7. ????????ELSE??
  8. ????????DBMS_OUTPUT.PUT_LINE('修改雇员工资失败!'); ??
  9. ?????????END?IF;? ??
  10. ????????END;??
SET SERVEROUTPUT ON 
		BEGIN
  		UPDATE emp SET sal=sal+100 WHERE empno=1234;
 		 IF SQL%FOUND THEN 
   		DBMS_OUTPUT.PUT_LINE('