千家信息网

UniDAC使用教程(九):提高性能

发表于:2024-11-23 作者:千家信息网编辑
千家信息网最后更新 2024年11月23日,下载UniDAC最新版本Universal Data Access Components (UniDAC)是一款通用数据库访问组件,提供了多个数据库的直接访问,如针对Windows的Delphi, C
千家信息网最后更新 2024年11月23日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属性,可以获得很少的额外性能改进。


0