Oracle中游标(二)
一、游标的属性
显性游标的属性
| 属性 | |
|
游标名称%FOUND
|
当最近一次读记录时成功返回,则值为TRUE;
|
|
游标名称%NOTFOUND
|
当最后一次没有找到数据时
|
|
游标名称% ROWCOUNT
|
返回由INSERT、UPDATE或DELETE 所影响的行数以及由SELECT INTO所选择的行数。
|
|
游标名称%ISOPEN
|
当游标已打开时返回 TRUE
|
隐式游标属性
SQL%NOTFOUND属性
SQL%FOUND属性
SQL% ROWCOUNT属性
游标属性的访问
游标名称%游标属性名。
由于隐性游标的名称是“SQL”,所以访问方法:SQL%游标属性名。
二、游标的使用
当需要操作该结果集时,必须完成三步:
1. 打开游标
2. 使用fetch语句将游标里的数据取出
3. 关闭游标。
使用loop循环和游标
Declare
v_empno number(4);
v_ename varchar2(20);
Cursor c_emp is select empno, ename from emp;
Begin
open c_emp;
loop
fetch c_emp into v_empno, v_ename;
exit when c_emp%notfound;
dbms_output.put_line(v_empno ||' '||v_ename );
end loop;
close c_emp;
End;
使用while循环和游标
Declare
v_empno number(4);
v_ename varchar2(20);
Cursor c_emp is select empno, ename from
emp;
Begin
open c_emp;
fetch c_emp into v_empno, v_ename;
while c_emp%found loop
dbms_output.put_line(v_empno ||' '||v_ename );
fetch c_emp into v_empno, v_ename;
end loop;
close c_emp;
End;
使用for循环和游标
DECLARE
v_empRecord EMP%ROWTYPE;
CURSOR c_emp is select empno, ename from emp;
BEGIN
FOR v_empRecord IN c_emp LOOP
dbms_output.put_line(v_empRecord.empno ||' '|| v_empRecord.ename );
END LOOP;
END;

浙公网安备 33010602011771号