DELPHI盒子
!实时搜索: 盒子论坛 | 注册用户 | 修改信息 | 退出
检举帖 | 全文检索 | 关闭广告 | 捐赠
技术论坛
 用户名
 密  码
自动登陆(30天有效)
忘了密码
≡技术区≡
DELPHI技术
lazarus/fpc/Free Pascal
移动应用开发
Web应用开发
数据库专区
报表专区
网络通讯
开源项目
论坛精华贴
≡发布区≡
发布代码
发布控件
文档资料
经典工具
≡事务区≡
网站意见
盒子之家
招聘应聘
信息交换
论坛信息
最新加入: hxh57738897
今日帖子: 23
在线用户: 23
导航: 论坛 -> DELPHI技术 斑竹:liumazi,sephil  
作者:
男 xfyserver (s) ★☆☆☆☆ -
普通会员
2018/11/6 21:50:31
标题:
三层数据数据更新的问题 浏览:784
加入我的收藏
楼主: 我在COM+组件中利用两个TAdoQuery构造了一个主从关系,并通过一个TDataSetProvider和一个TClientDataSet使用接口方法向客户端提供数据:
如:
procedure GetMDData2(var VData: OleVariant);
begin
try
CDSmaster.Active:=False;
VData:=CDSmaster.Data;
SetComplete;
except
SetAbort;
end;
end;
在客户端使用一个TClientDataSet和一个二级TClientDataSet(使用TDataSetField字段)接收数据,能够正确的运行.
如:
begin
ClientDataSet2.DataSetField:='Adoqry1';//使用了TDataSetField字段
ClientDataSet1.Data:=Fmts.GetData;//由COM+组件返回数据
end;

但是在更新时出现了问题:
用于更新的TDataSetProvider作了如下设置
   ResolveToDataSet = True
   Options = [poFetchBlobsOnDemand, poCascadeDeletes, poCascadeUpdates, poAllowMultiRecordUpdates, poAllowCommandText, poRetainServerOrder]
更新用的接口方法如:
procedure UpdateDataMD2(VData: OleVariant);
begin
try
CDSmaster.Active:=True;
CDSmaster.Data:=VData;
CDSmaster.ApplyUpdates(-1);
SetComplete;
except
SetAbort;
end;
end;

1.只能更新主表 2。从表总是不能被更新 3.当从表数据有修改等时,主表的更新不被存盘.


这个是网上的提问, 但网上并没有指出解决办法
我现在遇到相似的问题,
请高手指导一下
----------------------------------------------
-
作者:
男 lyq2276959 (along) ★☆☆☆☆ -
普通会员
2018/11/6 22:33:43
1楼: 要设置根据关键字段更新。
----------------------------------------------
-
作者:
男 hnxxcxg (咏南中间件) ★☆☆☆☆ -
盒子活跃会员
2018/11/8 12:55:36
2楼: https://www.cnblogs.com/hnxxcxg/p/4136725.html
多表数据提交
----------------------------------------------
中间件QQ群: 92449782 博客: http://www.cnblogs.com/hnxxcxg/
信息
登陆以后才能回复
Copyright © 2CCC.Com 盒子论坛 v3.0.1 版权所有 页面执行58.59375毫秒 RSS