加入收藏 | 设为首页 | 会员中心 | 我要投稿 衡阳站长网 (https://www.0734zz.cn/)- 数据集成、设备管理、备份、数据加密、智能搜索!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

UniDAC使用教程九提高性能

发布时间:2022-07-06 14:22:27 所属栏目:MySql教程 来源:互联网
导读:下载UniDAC最新版本 Universal Data Access Components (UniDAC)是一款通用数据库访问组件,提供了多个数据库的直接访问,如针对Windows的Delphi, C++Builder, Lazarus (以及 Free Pascal) , Mac OS X, iOS, Android, Linux和64和32位的FreeBSD等等。我们将
  下载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属性,可以获得很少的额外性能改进。
 

(编辑:衡阳站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读