如何优化Microsoft Access提高速度

 摘要
这篇文章介绍了在设计、编写和实现Microsoft Access
数据库 应用 程序 时为保证拥有最高速度而需要注意的几点。

介绍
作为一名
数据库 程序 员,你的主要任务是让你的用户能快速地选择、 管理 和访问他们所需要的信息。其他的工作几乎都是一成不变的,只要你的 数据库 应用 程序 执行速度越快,你的 程序 效率越高。这篇文章的目的就是突出各种不同的 技巧 和策略,通过优化 程序 来提高速度,让你的Microsoft Access 数据库 应用 程序 的效率更高,这样也可以帮助你完成作为一名 数据库 开发 者的主要使命。

瞄准速度问题的根本
为了提高你的
数据库 程序 的速度,自然而然地你会想到去注意影响速度最基本的几个部分,我们将从处理这几个部分着手。在你力图提高你的 数据库 程序 性能的时候,你的 程序 所运行的硬件平台将是唯一的决定因素。显而易见,实现优化的第一条原则应该是较快的硬件=较快的 数据库 ,当然CPU和RAM是这个等式的核心所在。相信你一定注意到Microsoft Access 所声明的,要达到一个令人满意的性能,至少需要8MB的RAM和一个80486的CPU。一般情况下,用户注意到这一点是理所应当的,但我却见过许多用户为他们的Microsoft Access 的执行速度而感到沮丧,当我问及他们使用什么机器运行此 程序 时,他们告诉我是一台80386,并且是在运行一台服务器上的一个MSACCESS.EXE。所以,在相信你的用户通过下面的方法固然能提高其 程序 性能的同时,始终需要强调的仍然是,在Microsoft Access 执行过程中,硬件才是关键的问题。

有效的磁盘访问
假定已经有了一个令人满意的硬件配置,下面让我们讨论一下如何才能提高Microsoft Access 在此平台上的运行速度。就这个问题,对你的
数据库 程序 而言,影响其性能的第二位因素就是磁盘访问了。在执行过程中,对物理磁盘的访问总是一个速度的瓶颈(与访问存储在 RAM中的数据相比较而言),所以,你应该尽量减少对磁盘的访问。然而,由于你的应用 程序 总是要和一些磁盘或其他一些物理设备打交道,所以,你的目标应该是保证所有的磁盘访问都尽可能有效。要实现这一点,方法是经常整理你的磁盘数据碎片,整理你的 数据库 所在的磁盘驱动器以及所有你执行你的 数据库 程序 时要涉及的磁盘驱动器,而且你还应提醒你的用户定期清理磁盘碎片,以此保证磁盘访问一直有效。这将最大程度地减少在对物理磁盘进行读写而花费的时间,尽管这些读写是不可避免的,同时优化了整个体系的性能。

使RAM最大化/对磁盘访问的频率最小化
下一个主题是使你的
数据库 程序 与物理磁盘驱动器打交道的频率最小。要做到这一点关键是尽可能多的释放RAM空间给你的应用 程序 使用。要实现这一点,你需要做到以下几点:
增加最大缓冲区的尺寸
首先涉及到你对最大缓冲区尺寸的设置。最大缓冲区的尺寸指的是Microsoft Access作为内部存储空间而保留的RAM的数目。存储空间越大,用户需求的数据能在RAM中找到可能性越大,同时减少了对物理磁盘的访问频率。Microsoft Access 需要的最小缓冲区是512KB,如果你的硬件
系统 有多于4MB的RAM,那么你就可以为Microsoft Access 多分配一些供其使用(这样也增加了 系统 的性能)。要做到这一点,只需要在MSACCESS.INI(在你的windows目录下)文件中增加对最大缓冲区的设置,使用你的文本编辑器,例如记事本,在此文件中找到 [Option] 段,在其中加这样一句话:MaxBufferSize = xxxxx
这其中的xxxxx即是为你的应用
程序 对存储空间分配而作的新设置(例如,设置MaxBufferSize=2048将为Microsoft Access分配2MB的缓冲区空间)。那么,你究竟应该分配多少才算合适呢?除了“尽可能多”,其他的还真难说。你需要手动地调节这个设置,同时需要试着让你的硬件都能提供以下条件:1)不能妨碍用户同时正在运行的 程序 ,2)不会影响其自身底层操作 系统 的运行效率(你可能会在 程序 启动时想通过.INI文件查看一下Microsoft Access自身的配置,因此,任何对MSACCESS.INI文件的修改都将只能在下一次Microsoft Access启动时才能奏效,而对现在正在运行的Microsoft Access 程序 没有任何的影响)。
避免装载Wizards
为了释放更多的
内存 以供Microsoft Access使用,另一个你可以采取的步骤是:如果你不使用Wizards,那么就不要装载它。你可以打开MSACCESS.INI文件,找到[libraries]部分,在“wizards.mdb=ro”这一句之前加一个分号,这样就避免了自动加载Wizards。这样做将能够释放315B的RAM提供给Microsoft Access以作己用,这样做的好处不仅在于提高了运行时间的性能,同时使每个应用 程序 平均减少了大约10秒的安装时间。
解除墙纸/背景位图
解除标准windows墙纸背景可以释放RAM中任何一处25K到350K的空间。解除复杂的位图将释放更多的
内存 空间。
创建永久交换文件
创建一个永久交换文件(相对于临时文件而言)将增加你额外的性能。关于这一点,你可以求助于关于这方面的帮助文档,它将指导你在运行
数据库 应用 程序 的机器上创建这一文件。
到现在为止,我们已经解决了有关硬件平台、最大的磁盘访问效率的问题,并且为你的应用
程序 增加了有效的RAM存储空间,接下来让我们转向优化应用 程序 本身。

压缩 压缩
要保证经常性的 压缩 你的 程序 代码 。当你在 开发 和使用Microsoft Access 数据库 时,你要经常性地增加和删除数据、 代码 等等。现在的问题是Microsoft Access并不能有效地释放已分配的但被删除的对象空间,这将意味着即使你删除了一个对象,而这个对象仍然在你的 数据库 中占据空间。 压缩 数据库 将迫使Microsoft Access真正删除这些对象并回收其占据的空间,从而使得你的 数据库 尽量小但却更有效。我曾把逐字逐句查询的平均时间减少了30%——50%,而做到这一点仅仅是通过去 压缩 那些由于经常使用又缺乏 压缩 而变得过度膨胀的 数据库 程序 ,因此,在运行 程序 的过程中,不要忽视 压缩 过程的重要性。正如你要定期清除 硬盘 数据碎片一样,你和你的用户也应当定期 压缩 数据库 来保证它始终最有效地运行。

只用
代码
你可能希望通过宏操作来搭建一个应用 程序 的模型,一旦你开始优化你的 程序 的最终性能,一定要把所有的宏重新写成 代码 。这主要是因为Microsoft Access 代码 要比宏运行得快的多。但遗憾的是有三个宏操作你不能将他们改写成 代码 ,这三个宏是Autokeys、Autoexec和Addmenu操作,这三个宏在Microsoft Access中没有相应的等价类,因此你只能被迫使用他们。不过,你可以克服Autoexec的限制,只需要定义Autoexec为调用你的Access Basic Autoexec函数。

优化数据类型声明
当你在你的
代码 中声明数据类型时,你应该试着尽可能精确。因为若是一个变量的类型(如果没有特别声明,缺省为可变类型)非常灵活自由的话,那么这种类型同时也将是最浪费 内存 的一种类型。这样一来,如果你知道check Balance这个变量不需要超过4位小数精度的话,那么就把它定义成确定类型而不是可变类型。对你的过程函数的定义同样也可以如此操作(比如说,把函数PostCredit()声明为整形,而不是Function PostCredit())。请注意这样一个事实,如果你估计一个变量将会被处理成一个空值,那么你需要去把它定义成一个可变类型而不是一个确定的严格的数据类型,否则你会得到一个错误信息。同样地,要注意整形除法和浮点除法之间的差别。

经常使用From/Report变量
在你的
程序 中,你需要保证你能提前解决尽可能多的查询工作。这意味着什么呢?举个例子来说明:如果你想在 代码 中查阅一个名为[NetPrice]的 文本框 ,你可以使用这样一条语句:
Mytemprariable=Forms![Customer Invoice]![Net price]
对于这条指令,Microsoft Access首先在Forms对象里搜索名为[Customer Invoice]的表,一旦它找到这张表,Microsoft Access接下来寻找名为[NetPrice]的控制,并进行正确的操作。从这个例子可以看出,Microsoft Access经过两次查询最终确定我们指定的控制。如果你想在同一
程序 (函数或者子函数)中再次查询[Customer Invoice]表中任一控制,你可以删除可能会在下次出现的多余语句,而只使用如下语句:
Dim F as form
Set F = Forms![Customer Invoice]
现在,你的Form变量将自动指向Form[Customer Invoice],允许Microsoft Access 避免每次在你需要查找[Customer Invoice]表中任一对象时,都要把
数据库 的Form对象中全部搜。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值