oracle cursor(静态)记录
admin
2023-04-20 21:04:41
0

游标定义:
游标(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

相关内容

热门资讯

燃气发电与电池储能相结合,成为... 来源:市场资讯 (来源:i商周) 孟菲斯一座xAI数据中心的燃气轮机 人工智能的用电飙升,让数据中心...
景嘉微:JM11性能大幅提升,... 有投资者在互动平台向景嘉微提问:“董秘您好!关注到近期有用户反馈公司JM11显卡推出了适配windo...
原创 v... 影像的发展进一步推动,不少品牌推出了专业影像手机,拥有2亿像素摄像头、色彩还原摄像头、影像芯片、影像...
荣耀首款自研耳夹式耳机官宣即将... 快科技5月13日消息,日前,荣耀首席营销官关海涛宣布,荣耀全场景团队自研首款耳夹式耳机马上上市,并称...
谷歌推出Googlebooks... IT之家 5 月 13 日消息,2026 年 I/O 开发者大会下周(5 月 19~20 日)召开之...
自控所推动GNC专业智能化升级 来源:滚动播报 (来源:中国航空报) 本报讯 5月6日,航空工业自控所召开 GNC+AI关键技术研发...
华电电力申请数据库访问方法专利... 国家知识产权局信息显示,华电电力科学研究院有限公司申请一项名为“数据库访问方法、装置、设备及介质”的...
苏州率先打造数据流通利用新范式 数据,作为第五大生产要素 具有流动性强、非消耗性、非均质性等特点 苏州率先打造数据流通利用新范式 夯...
伊媒披露伊美新一轮谈判5个先决... 当地时间5月12日,据伊朗法尔斯通讯社援引知情人士消息报道,伊朗对与美国新一轮谈判提出的5个先决条件...
英国将向霍尔木兹海峡多国护航行... 当地时间12日,总台记者从英国国防部获悉,英国将向在霍尔木兹海峡执行任务的多国护航行动提供无人机、战...