Delphi数据库开发之TBDEDataSet.CachedUpdates
2020-02-16 16:58
357 查看
以前的标题不是很恰当,还是改一下比较好。
TBDEDataSet都会有CachedUpdates这个属性,中文该怎么叫实在想不出一个好听点的名字,“缓冲更新”的叫法有点硬。当这个属性为True时,客户端对数据集的改变都保存在缓冲区内,不会立即发送的数据服务端,反之即然。Cachedupdates的优点是减少客户端与服务端之间的传送次数、减轻网络的输送量,尤其是在大负荷的网络或大批量的数据更新时,效果尤其明显。不过使用Cachedupdates为True时,要考虑以下这些问题:首先,当你对缓冲区的数据进行操作的时候,其他用户或进程是可以对服务端的数据存取的;直到Update到服务器之前,其他用户或进程都无法得知数据已经改变。其次,主从表中使用CachedUpdates也要注意主表与从表关系上的问题。另外当数据来自于多个表,数据集为ReadOnly的时候,在向服务端发送更新时,必须指派一个UpdateObject处理多表的数据更新问题。
与CachedUpdates对应的过程有ApplyUpdates、CancelUpdates、RevertRecord。调用ApplyUpdates过程,会一次性把所有更改发送到服务端,所有更新都会在放一个事务内。CancelUpdates是取消上一次ApplyUpdates至今所有对数据的修改,把数据回复到上一次读取的状态。RevertRecord把当前记录恢复到修改之前的状态。
TBDEDataSet都会有CachedUpdates这个属性,中文该怎么叫实在想不出一个好听点的名字,“缓冲更新”的叫法有点硬。当这个属性为True时,客户端对数据集的改变都保存在缓冲区内,不会立即发送的数据服务端,反之即然。Cachedupdates的优点是减少客户端与服务端之间的传送次数、减轻网络的输送量,尤其是在大负荷的网络或大批量的数据更新时,效果尤其明显。不过使用Cachedupdates为True时,要考虑以下这些问题:首先,当你对缓冲区的数据进行操作的时候,其他用户或进程是可以对服务端的数据存取的;直到Update到服务器之前,其他用户或进程都无法得知数据已经改变。其次,主从表中使用CachedUpdates也要注意主表与从表关系上的问题。另外当数据来自于多个表,数据集为ReadOnly的时候,在向服务端发送更新时,必须指派一个UpdateObject处理多表的数据更新问题。
与CachedUpdates对应的过程有ApplyUpdates、CancelUpdates、RevertRecord。调用ApplyUpdates过程,会一次性把所有更改发送到服务端,所有更新都会在放一个事务内。CancelUpdates是取消上一次ApplyUpdates至今所有对数据的修改,把数据回复到上一次读取的状态。RevertRecord把当前记录恢复到修改之前的状态。
转载于:https://www.cnblogs.com/Byeah/archive/2004/07/08/3162431.html
- 点赞
- 收藏
- 分享
- 文章举报
相关文章推荐
- 《Delphi 面向对象编程思想》书评
- 又一灵异事件 Delphi 2007 在 Win7
- delphi stdcall 错误
- Delphi中Inputbox 和Inputquery 函数的使用
- Delphi ClientDataSet 主从结构 BUG
- SQL Server 2000 字段类型 Delphi 数据类型对照
- Delphi TreeView 节点上下移动
- Delphi Exif
- Delphi 字母 递增 递减算法
- delphi显示jpg、png、gif图片
- Delphi 关键字详解
- 基于Delphi的BHO开发基础
- 使用Delphi开发IE右键菜单扩展
- 初探Delphi中的插件编程
- 使用Delphi开发IE按钮扩展
- 转:用Delphi开发过滤特定网址的BHO插件
- Delphi开发嵌入式IE浏览器监控程序
- delphi使用IdTcpClient和IdTcpServer数据通信
- delphi 调用C# DLL程序集
- Delphi版本号对照(条件编译中用到)