UniDAC使用教程(九):提高性能
下载UniDAC最新版本
Universal Data Access Components (UniDAC)是一款通用数据库访问组件,提供了多个数据库的直接访问,如针对Windows的Delphi, C++Builder, Lazarus (以及 Free Pascal) , Mac OS X, iOS, Android, Linux和64和32位的FreeBSD等等。我们将长期的经验集于这个小组件,提供统一的数据库连接访问(如oracle、微软SQL等等)。这意味着您可以在您的项目之间轻松地切换不同的数据库,以及创建跨数据库应用程序接口。
本主题考虑使用数据集的基本阶段以及提高每个阶段性能的方法。
连接
如果应用程序经常执行连接/断开连接操作,则可以使用池模式(TCustomDAConnection.Pooling = True)获得额外的性能。它大大减少了连接重新打开时间(数百次)。这种情况通常发生在Web应用程序中。
执行
如果应用程序多次执行同一查询,则可以使用TCustomDADataSet.Prepare方法或设置TDADataSetOptions.AutoPrepare属性以提高性能。例如,它可以为Master/Detail 关系中的细节数据集或TDAUPDATESQL中的更新对象启用。通过这种方式获得的性能增益可以是百分之几到几倍,具体取决于具体情况。
要执行SQL语句,TUniSQL组件比TUniQuery更可取。它可以增加几个百分点的性能增益。
如果TCustomDADataSet.Options.StrictUpdate选项设置为False,则不计算RowAffected属性,该属性将变为等于零。这可以提高查询执行的性能,因此,如果您需要一次执行许多数据更新语句,并且不介意受影响的行数,请将此选项设置为False。
导航
当数据集在关键字段字段上进行本地排序时,Locate函数的工作速度更快。可以使用indexFieldNames属性设置本地数据集排序。如果数据集包含大量行,则性能增益可能很大。
当查找数据集在本地按查找键排序时,查找字段的工作速度更快。
在计算字段和查找字段上进行本地排序和定位时,设置TDadatasetOptions.CacheCalcFields属性可以提高性能。当计算字段表达式包含复杂的计算时,它也很有用。
设置TDADataSetOptions.LocalMasterDetail选项可以通过避免详细刷新时的服务器请求来大大提高性能。设置TDADataSetOptions.DetailDelay选项对于避免频繁切换主数据集记录时刷新详细信息非常有用。
更新
如果应用程序以CachedUpdates模式更新数据集,则将TCustomDADataSet.Options.UpdateBatchSize选项设置为1以上可以通过减少对服务器的请求数来提高性能几百倍。
通过使用Dataset.UpdateObject.ModifyObject、Dataset.UpdateObject等,您还可以稍微提高数据发送性能(几个百分点)。通过设置这些对象的AutoPrepare属性,可以获得很少的额外性能改进。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341