DELPHI盒子
!实时搜索: 盒子论坛 | 注册用户 | 修改信息 | 退出
检举帖 | 全文检索 | 关闭广告 | 捐赠
技术论坛
 用户名
 密  码
自动登陆(30天有效)
忘了密码
≡技术区≡
DELPHI技术
lazarus/fpc/Free Pascal
移动应用开发
Web应用开发
数据库专区
报表专区
网络通讯
开源项目
论坛精华贴
≡发布区≡
发布代码
发布控件
文档资料
经典工具
≡事务区≡
网站意见
盒子之家
招聘应聘
信息交换
论坛信息
最新加入: melqui
今日帖子: 4
在线用户: 1
导航: 论坛 -> DELPHI技术 斑竹:liumazi,sephil  
作者:
女 haikely (阿) ★☆☆☆☆ -
盒子活跃会员
2003/7/15 9:41:55
标题:
关于多层应用系统的多表更新问题?急!!! 浏览:2633
加入我的收藏
楼主: 我需要在远程数据模块中实现,当销售表更新的时候,根据其更新种类,对库存表进行更新."删除"和"新添"部分都经测试可以了,就是"编辑"的部分不行,请各位大虾帮帮忙.谢谢!!下面是我源代码.
"Data_3.db"是库存表
所有用的数据组件的"UpdateMode"都是"wherekeyonly"

procedure TYuYue_RDM_Server.Stock_I_Table_DAfterUpdateRecord(
  Sender: TObject; SourceDS: TDataSet; DeltaDS: TCustomClientDataSet;
  UpdateKind: TUpdateKind);
begin
  {更新"Data_3"的库存}
  self.Update_Data_3.Close;
  Case UpdateKind Of
    ukModify:{编辑}
      begin
        self.Update_Data_3.SQL.Clear;
        self.Update_Data_3.SQL.Add('Update "data_3.db" Set kc=kc+:Editkc where id=:D3ID');
        self.Update_Data_3.Prepare;
        self.Update_Data_3.ParamByName('Editkc').AsSmallInt:=(DeltaDS.Fields[4].NewValue-DeltaDS.Fields[4].OldValue);
        self.Update_Data_3.ParamByName('D3ID').AsSmallInt:=DeltaDS.Fields[2].Value;
      end;
    ukInsert: {删除}
      begin
        self.Update_Data_3.SQL.Clear;
        self.Update_Data_3.SQL.Add('Update "data_3.db" Set kc=kc-:Delkc where id=:D3ID');
        self.Update_Data_3.Prepare;
        self.Update_Data_3.ParamByName('Delkc').AsSmallInt:=DeltaDS.Fields[4].Value;
        self.Update_Data_3.ParamByName('D3ID').AsSmallInt:=DeltaDS.Fields[2].Value;
      end;
    ukDelete: {新添}
      begin
        self.Update_Data_3.SQL.Clear;
        self.Update_Data_3.SQL.Add('Update "data_3.db" Set kc=kc+:Addkc where id=:D3ID');
        self.Update_Data_3.Prepare;
        self.Update_Data_3.ParamByName('Addkc').AsSmallInt:=DeltaDS.Fields[4].Value;
        self.Update_Data_3.ParamByName('D3ID').AsSmallInt:=DeltaDS.Fields[2].Value;
      end;
    end;
  self.Update_Data_3.ExecSQL;


----------------------------------------------
-
作者:
女 haikely (阿) ★☆☆☆☆ -
盒子活跃会员
2003/7/19 9:31:13
1楼: UkModify一直无法被触发,有谁知道为什么吗???
----------------------------------------------
-
作者:
男 bios (阿贡) ★☆☆☆☆ -
盒子中级会员
2003/7/29 6:48:37
2楼: 我也想知道哪里出错了,但我也解决不了
你自己解决了吗?
如果解决可以贴出正确答案吗?谢谢!
----------------------------------------------
按此在新窗口浏览图片
按此在新窗口浏览图片
信息
登陆以后才能回复
Copyright © 2CCC.Com 盒子论坛 v3.0.1 版权所有 页面执行76.17188毫秒 RSS