WEB开发网
开发学院数据库Access 怎样优化Microsoft Access来提高速度 阅读

怎样优化Microsoft Access来提高速度

 2007-07-26 00:00:00 来源:WEB开发网   
核心提示: 优化数据类型声明当你在你的代码中声明数据类型时,你应该试着尽可能精确,怎样优化Microsoft Access来提高速度(4),因为若是一个变量的类型(如果没有特别声明,缺省为可变类型)非常灵活自由的话,你就能更好地完成你的任务,也就是向你的用户提供最有效的选择、管理、发送他们的数据的能力,那么

优化数据类型声明

当你在你的代码中声明数据类型时,你应该试着尽可能精确。因为若是一个变量的类型(如果没有特别声明,缺省为可变类型)非常灵活自由的话,那么这种类型同时也将是最浪费内存的一种类型。这样一来,如果你知道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对象中全部搜索一次。为了查阅控制[NetPrice],你只需要简单地使用下面的语句:

Mytempvariable=F![NetPrice]

Mytempvariable=F![NetPrice]

你也可以对Report对象作相同的操作(比如,set R=Reports![MyReport])。当你在一个函数中仅仅只对一个Form或Report访问一次,你可能在速度性能方面得不到什么太大得好处,但是一旦你开始在同一个Form或Report中进行的访问操作超过一次,你将会看到明显的时间减少。于是,通过使Microsoft Access避免作多余的查阅,你将大大地提高你程序的速度。

在可以应用的地方使用windows函数

无论何时,只要相关,总是可以用一个windows函数调用来代替Access Basic代码执行同一个操作。这样你将节省开发时间,因为windows函数调用是已经完成编码并经过优化,同时也因为它们是用C语言编写的(机器可执行),而Access Basic代码则要被编译成P代码形式,同时需要在执行时一行一行地解释。一个最普通的例子是custom.ini设置。你可以使用Access Basic文件函数去得到一个自由文件指针,打开文件,读/写文件,然后关闭它。但是如果你完全可以简单地使用GetPrivateProfileString和WritePrivateProfileString函数来实现,它们既快且已经编码优化随手可用,你为什么还要自寻烦恼呢?(参考:“Enhanced Microsoft Access: Using the Win16 API”)

你的Microsoft Access数据库应用程序运行速度越快,你就能更好地完成你的任务,也就是向你的用户提供最有效的选择、管理、发送他们的数据的能力。我真诚希望以上这些小技巧能协助你达到这个目标。

上一页  1 2 3 4 

Tags:怎样 优化 Microsoft

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接