首页 > 开发 > 综合 > 正文

加速PL/SQL过程

2024-07-21 02:37:53
字体:
来源:转载
供稿:网友

  在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程序的执行速度更快,因为它消除了和解释字节代码有关的延迟,而且在本机代码里提供了更好的流控制,这一点要比在解释型代码里的更好。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表