首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何应用更新-使用dbnavigator还是在代码中?

如何应用更新-使用dbnavigator还是在代码中?
EN

Stack Overflow用户
提问于 2014-02-03 07:10:30
回答 2查看 1.7K关注 0票数 0

我在Datasnap客户机-服务器SQLite中使用一个scenario..To数据库,避免使用dbnavigator将更新应用到客户端集中,我想知道是否有其他选择。这是一个很好的选择吗?

代码语言:javascript
复制
procedure TForm2.ClientDataSet1AfterPost(DataSet: TDataSet);
begin
ClientDataSet1.ApplyUpdates(0);
end;

我的推理是,在post之后,当您插入或更新一个记录时会发生这样的情况,因此插入代码以避免为此目的使用dbnavigator是一个很好的地方。这个推理可以吗?另一种选择?或者,在Datasnap的情况下,使用dbnavigator更好吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-02-03 10:44:27

将任何更改立即应用于在ApplyUpdates事件中调用AfterPost的数据库是一种完全有效的方法。不过,您应该对AfterDelete也这样做。

顺便说一句,您不必使用DBNavigator来调用ApplyUpdates。在您的程序中可能有合适的点(例如,FormClose)。

票数 2
EN

Stack Overflow用户

发布于 2014-02-03 13:00:33

如前所述,在发布和删除后调用TClientDataset.ApplyUpdates确实是完全有效的,但请记住,这样做将增加客户机和服务器之间的往返。在某些情况下,这可能会产生性能问题。

特别是,我更喜欢让用户以一种形式执行许多操作,并在一次往返中应用这些操作。为了做到这一点,我通常有一个提交或保存按钮连接到一个特定的动作,当<clientDataset>.State in [dsEdit, dsInsert] or <clientDataset>.ChangeCount>0启用。

这只是一个偏好的问题,但在我看来,这是一个很好的比喻,用户和给他/她机会建立一批操作(插入,删除和更新),以保存在一个时刻。

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

https://stackoverflow.com/questions/21521598

复制
相关文章

相似问题

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