游标定义:
游标(Cursor)是处理数据的一种方法,为了查看或者处理结果集中的数据,游标提供了在结果集中一次一行或者多行前进或向后浏览数据的能力。可以把游标当作一个指针,利用游标可以返回它当前指向的行记录(只能返回一行)若要返回多行,则需要不断的滚动,把想要的数据全部查询一遍。游标可以指定结果中的任何位置,然后允许用户对指定位置的数据进行处理。
游标的优点:
1)允许程序对由查询语句select返回的行集合中的每一行执行相同或不同的操作
,而不是对整个行集合执行同一个操作。
2)提供对基于游标位置的表中的行进行删除和更新的能力。
游标的缺点:
在创建游标时,最需要考虑的事情是,“是否有办法避免使用游标?”因为游标的效率较差,如果游标操作的数据超过1万行,那么就应该改写;如果使用了游标,就要尽量避免在游标循环中再进行表连接的操作。
静态游标分为:
显式游标和隐式游标
显示游标部分:-->
1.游标的语法:
CURSOR cursor_name (parameter_name datatype) IS select...
2.显示游标的使用步骤:
1.声明游标 2.打开游标 3.读取游标 4.关闭游标
3.显示游标的四个属性:
1.Cursorname%found
2.Cursorname%notfound
3.Cursorname%isopen
4.Cursorname%rowcount
4.显示游标示例:
示例1:
declare
cursor c is select * from dj_djb where slbh like ‘201708%‘;
v_djb dj_djb%rowtype;
begin
open c;
loop
--exit when c%notfound;
if c%isopen then
dbms_output.put_line(‘游标已经打开!‘);
fetch c into v_djb;
exit when c%notfound;
dbms_output.put_line(v_djb.slbh);
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
原文地址:http://blog.51cto.com/wolihaito/2091221