微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PL/SQL编程经验小结开发者网络Oracle

正在看的ORACLE教程是:PL/sql编程经验小结开发者网络Oracle。平时在PL/sql中的编程中遇到一些问题,这里以问答的形式来进行把它们总结下来,以供大家分享。   1、当需要向表中装载大量的数据流或者需要处理大量的数据流的时候,能否使用管道提高处理效率?
管道函数对于改善并行查询性能非常方便,它加快往表中加载数据的速度。管道函数的使用总结如下两点:   每当在查询里使用PL/sql函数时,该查询将被序列化,即一个处理器只能运行一个查询实例,那么在这种情况下不可能使用并行查询(比如在数据仓库中要经常使用这项技术)。因此,为了使用并行查询就必须使用管道函数,这样也就加快了执行的速度。   管道函数的输入参数必须是一个引用记录集类型(即refcursor),而返回的是嵌套表类型(其表中每一行对应每一个引用记录)。在使用管道函数之前,必须先在程序头写上ParaLLEL_ENABLE,这样才能在查询语句中使用管道函数来处理了。   2.如何使PL/sql程序等待一段时间执行?
 
  方法就是使用DBMS_LOCK包的SLEEP函数,可以进行精确定时,其语法为: DBMS_LOCK.SLEEP(secondsINNUMBER);   3.需要在一张表插入一条记录之后等若干秒后再执行另外一个操作,如何在PL/sql程序里进行定时操作?   一般的做法是用循环作延迟,利用DBMS_UTILITY的gettime函数来检测当前的时间,程序代码如下:
  另外如果是不同会话(session)之间的定时,就必须使用DBMS_PIPE包的函数来实现会话间的消息传递。   4.当PL/sql返回一个数据集的时候,该使用集合还是游标?   一般情况下,有以下两点作为依据:   1)如果PL/sql程序返回多多行数据给另外一个PL/sql程序的话,这里就建议使用集合,因为这样可以利用集合的批收集(bulkcollection)来提高从数据库提取数据的速度。   2)如果需要在PL/sql程序的环境中把数据返回到宿主语言环境中(如sql*plus,c,delphi等),这时应该使用游标变量来返回这些数据,因为几乎所有的宿主语言都支持游标变量,但不是所有的宿主语言都支持集合。这样可以增强程序的可移植性。   5.如何更有效的在PL/sql中使用游标?   游标是PL/sql一个非常重要的概念,对数据库的检索主要依靠游标来操作。在PL/sql中有两类游标,一类是隐式游标,如selectclnointov_clnofromtable_detail.另外一类是显式游标,如cursorv_curisselectclnofromtable_detail。对于游标的使用这里给出以下几点建议:   1)尽可能的使用bulkcollection。它能够较大的提高运行性能,在Oracl9i的第二版,甚至可以使用bulkcollection来直接将数据写入到记录表   2)尽量使用显式游标来处理,因为相对于隐式游标来说,显式游标的速度更快一些。   3)如果查询的表很小或者是静态的,可以把该表缓存到一个包级的集合里。这样,你的查询函数就直接从集合里(即进程全局区,PGAcache),而不是从系统全局区(SGA)来取数据,这样的处理速度会提升很多。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐