教你如何加速PL/SQL

原创|其它|编辑:郝浩|2009-04-17 11:31:51.000|阅读 494 次

概述:本文介绍了如何加速PL/SQL的方法。

# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>

  在Oracle9i引入的所有新特性中,编译型的PL/SQL是最让人激动的进步。从Oracle9i开始,我们可以编译PL/SQL骨架,初步的报告显示,代码运行的速度要比解释型的PL/SQL快7倍。
  
  在这之前,Oracle PL/SQL的特性之一就是:它是一门解释型的语言。在解释型语言里,每一行代码都会在移动到下一行代码之前被单独剖析和执行。尽管解释型语言会给PL/SQL的运行带来巨大的灵活性,但是它的不足之处是信息无法被打包进一个紧密的可执行模块——你可以在运行期间就从操作系统里直接运行这个模块。
  
  Oracle9i所引入的这些变化带来了很多好处。我们现在可以把Oracle代码隐藏在一个可执行文件里。在Oracle9i之前的版本里,预备出售PL/SQL程序段的商用开发者别无选择,只有答应它们的客户看到其PL/SQL的真实源代码。今天,Oracle的开发人员能够通过直接向其客户提供可执行文件而隐藏掉PL/SQL的细节。
  
  而且,Oracle的代码在编译模块里会运行的快得多。Oracle估计使用编译型的PL/SQL要比使用传统的PL/SQL快1到7倍。
  
  它最好的一点是让Oracle PL/SQL的编译变得相当轻松。和PL/SQL程序相对应的、已编译的代码被映射到PGA(而不是SGA),从而获得更好的并发访问。有了本机的编译,不含有SQL参照的PL/SQL可以快1到7倍。
  
  为了启动本机编译,要使用下面的陈述式:
  
  ALTER SESSION SET plsql_compiler_switches=NATIVE;
  
  在Oracle9i里,一个PL/SQL的库单元可以被作为本机C代码编译,而不是作为字节代码被解释。它然后就会作为文件系统里的一个共享库被保存。编译PL/SQL函数或者进程的过程非常简单,就像下面这样:
  
  ALTER FUNCTION my_func COMPILE;
  
  编译使得PL/SQL程序的执行速度更快,因为它消除了和解释字节代码有关的延迟,而且在本机代码里提供了更好的流控制,这一点要比在解释型代码里的更好。


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com

文章转载自:网络转载

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP