游标的概念:
??? 游标是SQL的一个内存工作区,由系统或用户以变量的形式定义。游标的作用就是用于临时存储从数据库中提取的数据块。在某些情况下,需要把数据从存放在磁盘的表中调到计算机内存中进行处理,最后将处理结果显示出来或最终写回数据库。这样数据处理的速度才会提高,否则频繁的磁盘数据交换会降低效率。
游标有两种类型:显式游标和隐式游标。在前述程序中用到的SELECT...INTO...查询语句,一次只能从数据库中提取一行数据,对于这种形式的查询和DML操作,系统都会使用一个隐式游标。但是如果要提取多行数据,就要由程序员定义一个显式游标,并通过与游标有关的语句进行处理。显式游标对应一个返回结果为多行多列的SELECT语句。
游标一旦打开,数据就从数据库中传送到游标变量中,然后应用程序再从游标变量中分解出需要的数据,并进行处理。
隐式游标
如前所述,DML操作和单行SELECT语句会使用隐式游标,它们是:
* 插入操作:INSERT。
* 更新操作:UPDATE。
* 删除操作:DELETE。
* 单行查询操作:SELECT ... INTO ...。
当系统使用一个隐式游标时,可以通过隐式游标的属性来了解操作的状态和结果,进而控制程序的流程。隐式游标可以使用名字SQL来访问,但要注意,通过SQL游标名总是只能访问前一个DML操作或单行SELECT操作的游标属性。所以通常在刚刚执行完操作之后,立即使用SQL游标名来访问属性。游标的属性有四种,如下所示。
- 隐式游标的属性?返回值类型???意????义 ??
- SQL%ROWCOUNT????整型??代表DML语句成功执行的数据行数 ??
- SQL%FOUND???布尔型?值为TRUE代表插入、删除、更新或单行查询操作成功 ??
- SQL%NOTFOUND????布尔型?与SQL%FOUND属性返回值相反 ??
- SQL%ISOPEN??布尔型?DML执行过程中为真,结束后为假??
隐式游标的属性 返回值类型 意 义 SQL%ROWCOUNT 整型 代表DML语句成功执行的数据行数 SQL%FOUND 布尔型 值为TRUE代表插入、删除、更新或单行查询操作成功 SQL%NOTFOUND 布尔型 与SQL%FOUND属性返回值相反 SQL%ISOPEN 布尔型 DML执行过程中为真,结束后为假
【训练1】 使用隐式游标的属性,判断对雇员工资的修改是否成功。
步骤1:输入和运行以下程序:
- SET?SERVEROUTPUT?ON? ??
- ????????BEGIN??
- ????????UPDATE?emp?SET?sal=sal+100?WHERE?empno=1234; ??
- ?????????IF?SQL%FOUND?THEN? ??
- ????????DBMS_OUTPUT.PUT_LINE('成功修改雇员工资!'); ??
- ????????COMMIT;? ??
- ????????ELSE??
- ????????DBMS_OUTPUT.PUT_LINE('修改雇员工资失败!'); ??
- ?????????END?IF;? ??
- ????????END;??
SET SERVEROUTPUT ON BEGIN UPDATE emp SET sal=sal+100 WHERE empno=1234; IF SQL%FOUND THEN DBMS_OUTPUT.PUT_LINE('