标签:cursor游标
游标定义:dbms_output.enable(buffer_size=>null);
dbms_output.put_line(c%rowcount);
else
dbms_output.put_line(‘游标未打开!‘);
end if;
end loop;
end;
示例2
使用: cursor for loop ......
declare
cursor c is select * from dj_djb where slbh like ‘201708%‘;
v_djb dj_djb%rowtype;
begin
for i in c loop
dbms_output.put_line(i.slbh);
dbms_output.put_line(c%rowcount);
end loop;
end;
使用 bulk collect into ....进行批量提取数据
declare
cursor c is select * from dj_djb where slbh like ‘201708%‘;
type v_djb_tmp is table of dj_djb%rowtype index by binary_integer;
v_djb v_djb_tmp;
begin
open c;
loop
fetch c bulk collect into v_djb limit 10;
for i in 1..v_djb.count loop
dbms_output.enable(buffer_size=>null);
dbms_output.put_line(v_djb(i).slbh||‘ 对应的行数:‘||i);
end loop;
dbms_output.put_line(c%rowcount);
exit when c%notfound;
end loop;
close c;
end;
隐式游标部分-->
隐式游标则由则由系统自动定义,非显示定义游标的DML语句即被赋予隐式游标属性。其过程由oracle控制,完全自动化。隐式游标的名称是SQL,不能对SQL游标显式地执行OPEN,FETCH,CLOSE语句。
隐式游标的属性:
类似于显示游标,隐式游标同样具有四种属性,只不过隐式游标以SQL%开头,而显示游标以Cursor_name%开头。通过SQL%总是只能访问前一个DML操作或单行SELECT操作的游标属性,用于判断DML执行的状态和结果,进而控制程序的流程。
SQL%ISOPEN :
游标是否打开。当执行select into ,insert update,delete时,Oracle会隐含地打开游标,且在该语句执行完毕或隐含地关闭游标,因为是隐式游标,故SQL%ISOPEN总是false
SQL%FOUND :
判断SQL语句是否成功执行。当有作用行时则成功执行为true,否则为false。SQL%NOTFOUND :
判断SQL语句是否成功执行。当有作用行时否其值为false,否则其值为true。
SQL%ROWCOUNT:
在执行任何DML语句之前,SQL%ROWCOUNT的值都是NULL。
by wolihaito 2018.03.26
标签:cursor游标
原文地址:http://blog.51cto.com/wolihaito/2091221