正 文

加速PL/SQL过程


www.7dspace.com  更新日期:2005-11-7 3:06:09  七度空间


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

本文作者: Donald Burleson做数据库管理员已经有23年了,曾经写过14本关于数据库的书和超过100篇的文章。他是《Oracle内幕(Oracle Internals)》的主编,并经营着Burleson Oracle咨询公司(Burleson Oracle Consulting)。


上一篇:在Oracle 9i里对基于函数的索引进行仅索引扫描
下一篇:数据库管理:Oracle 缓冲区忙等待的原因
作者:Donald Burleson  来源:开发者在线 ( 责任编辑:7dspace )
收藏此页】【打印】【关闭
站 内 搜 索
 

热 点 导 读
特 别 推 荐