游标有两种类型:显式游标和隐式游标。SELECT...INTO...查询语句,一次只能从数据库中提取一行数据,对于这种形式的查询和DML操作,系统都会使用一个隐式游标。但是如果要提取多行数据,就要由程序员定义一个显式游标,并通过与游标有关的语句进行处理。显式游标对应一个返回结果为多行多列的SELECT语句。 游标一旦打开,数据就从数据库中传送到游标变量中,然后应用程序再从游标变量中分解出需要的数据,并进行处理。
隐式游标
如前所述,DML操作和单行SELECT语句会使用隐式游标,它们是: * 插入操作:INSERT。 * 更新操作:UPDATE。 * 删除操作:DELETE。
* 单行查询操作:SELECT ... INTO ...。
当系统使用一个隐式游标时,可以通过隐式游标的属性来了解操作的状态和结果,进而控制程序的流程。隐式游标可以使用名字SQL来访问,但要注意,通过SQL游标名总是只能访问前一个DML操作或单行SELECT操作的游标属性。所以通常在刚刚执行完操作之后,立即使用SQL游标名来访问属性。游标的属性有四种,如下所示。
1. 隐式游标的属性 返回值类型 意 义
2. SQL%ROWCOUNT 整型 代表DML语句成功执行的数据行数
3. SQL%FOUND 布尔型 值为TRUE代表插入、删除、更新或单行查询操作成功
4. SQL%NOTFOUND 布尔型 与SQL%FOUND属性返回值相反
5. SQL%ISOPEN 布尔型 DML执行过程中为真,结束后为假
【训练1】 使用隐式游标的属性,判断对雇员工资的修改是否成功。 步骤1:输入和运行以下程序:
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;
运行结果为:
1. 修改雇员工资失败!
2. PL/SQL 过程已成功完成。
步骤2:将雇员编号1234改为7788,重新执行以上程序:
运行结果为:
1. 成功修改雇员工资!
2. PL/SQL 过程已成功完成。
说明:本例中,通过SQL%FOUND属性判断修改是否成功,并给出相应信息。
















