首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Access 2007链接表性能

Access 2007链接表性能
EN

Stack Overflow用户
提问于 2010-09-08 22:05:50
回答 2查看 3.8K关注 0票数 3

我有一个Access 2007应用程序(以前在Access 2003中),当链接的数据库表位于网络驱动器上时,它会遇到一些性能问题。在2003年,该应用程序运行得非常好。现在,在2007年,使用sql和记录集检索数据的速度下降得非常慢。我遇到这个问题的确切位置是:

代码语言:javascript
复制
DIM rs AS NEW ADODB.RECORDSET
rs.Open tsSql, CurrentProject.AccessConnection, iKeyset, iLock

iKeyset设置为0,iLock设置为3

rs.Open命令需要4-5秒的时间,这是一个问题,因为在我的一些表单上,这可能会在加载时多次发生。

有什么想法吗?

编辑:更不用说我认为在这种情况下,在“设计”视图中打开和保存窗体的速度比正常情况下要慢。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-10-05 16:26:57

根据所涉及的SQL语句(即上面的变量'tsSQL‘),无论是ADO还是DAO,您的记录集都应该立即打开。

我脑海中浮现的想法是:你们的联系是持久的吗?这似乎在2007年造成了比2003年更多的延迟。也许它每次都会丢弃并重新建立连接。在表单中,当你的记录源是空的并且设置在代码中时,就会发生这种情况,所以建议你总是有一个记录源,比如"tblBlankTable“(一个只有一条记录的小表,用来在总是打开的表单中保持连接始终有效)。4到5秒的延迟是指您在此情况下得到的结果。在运行rs.open时,请尝试确保表单始终连接到数据库,并查看是否有效。在这种情况下,您可能需要打开ADO连接的窗体。在Access论坛上有很多关于这方面的文章。

当您是唯一的用户时,是否比其他人打开了锁文件的数据库更快?这是一个很好的信号。

另一个想法是在升级时是否正确地索引了所有内容。底层数据库是保持不变还是从MDB升级到ACCDB?您没有指明tSQL中的内容,因此您可能正在连接非索引字段或导致特定tSQL运行缓慢的某些东西,只需要添加一个主键即可。

如果你的“tsSQL”涉及查询,我读到在升级时重新编译所有查询是很重要的--进入设计模式,然后运行它们,然后再次保存它们。

您可以尝试使用自己的连接字符串连接到数据库-- MDB/Jet有一种格式,ACCDB/Ace有另一种格式。从Excel到MDB或ACCDB,人们通常都会使用这两者的提供程序,但也许可以在Access中工作,至少调试您的问题。

票数 1
EN

Stack Overflow用户

发布于 2010-09-10 08:59:53

有一个提到性能问题的热修复Description of the Access 2007 hotfix package (Access.msp): August 26, 2008,但是这很可能包含在Access 2007 SP2中。单击“>>”按钮“Office Access选项”(右下角)“Office资源”选项卡,然后查看标题为“关于Microsoft Office Access 2007”的部分所显示的内容。我的状态为12.0.6535.5005)。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3668526

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档