设为首页 收藏本站
查看: 1360|回复: 0

[经验分享] 游标For..Loop与Open..Close的比较

[复制链接]

尚未签到

发表于 2019-1-26 14:58:28 | 显示全部楼层 |阅读模式
最近,在项目开发过程中,通过在存储过程、函数、包的使用过程,对游标有了一定的认识,所以,总结下来。
首先,举一个简单的例子,来比较一些通过For..Loop读取游标和Open..Close的区别。
-- declare
   -- this cursor is get table employee's info

cursor   cur_employee   is
       select  *   from   employee;

         -- this curso is get table dept's info

cursor   cur_dept   is
       select  *   from   dept;

         -- this cursor is get table employee & dept  info

cursor  cur_info  is
       select  e.*,   d.dept_name
    from  employee e ,  dept d
    where  e.dept_no  =  d.dept_no(+);

        -- to save cursor record's value

v_employee_row employee%rowtype;
v_dept_row dept%rowtype;

-- for .. loop
for v_row in cur_employee loop
   -- TODO-A
end loop;
   -- TODO-B

-- open ..close
open cur_employee
    fetch cur_employee into v_employee_row;
close cur_table_test;

1.使用For..Loop的方式读取cursor,open、fetch、close都是隐式打开的。所以,不用担心忘记关闭游标而造成性能上的问题。
2.使用For..Loop的代码,代码更加干净、简洁,而且,效率更高。
3.使用For..Loop读取游标后,存储记录的变量不需要定义,而且,可以自动匹配类型。假如读取多个表的记录,显然用Open的fetch..into就显得相当困难了。
     fetch cur_info into X (这里的就相当麻烦,而且,随着涉及的表、字段的增加更加困难)     
    4.For..Loop在使用游标的属性也有麻烦的地方。因为记录是在循环内隐含定义的,所以,不能在循环之外查看游标属性。
         假如要做这样的处理:当游标为空时,抛出异常。把下面的读取游标属性的代码:
if   cur_employee%notfound  then
   -- can not found record form cursor
    RAISE_APPLICATION_ERROR(error_code, error_content);
end if;
放在>的位置,虽然编译可以通过,但在运行时,就会报错:ORA-01001:invalid cursor
放在>的位置,读取游标的notfound属性。显然,也是不行的。因为,如果游标为空的话,就会直接跳出循环,根本不会执行循环体内的代码。但是,也并不是说,就不能使用For..Loop来处理了。可以通过设置标志字段处理。
定义变量:v_not_contain_data bollean default true;
For..Loop循环内增加一行代码:v_not_contain_data := false;
这样,在循环体外可以通过标志位来判断:
         If v_not_contain_data then
     RAISE_APPLICATION_ERROR(error_code, error_content);
end if;






运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-667914-1-1.html 上篇帖子: Open Source Bing Maps API for ASP.NET MVC 下篇帖子: MVP Open Day手记——场上场下同样精彩
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表