zoukankan      html  css  js  c++  java
  • ClientDataSet中修改,删除,添加数据和Delta属性

    ClientDataSet中使用Post提交变更的数据时,实际上并没有更新到后端数据库中,而是提交到了由DataSnap管理的数据缓冲区中。当使用了ClientDataSet.ApplyUpDates(MaxErrors:integer)方法才更新到数据库中。ApplyUpDates方法也只更新修改的数据,这些数据放在ClientDataSet.Delta属性中。调用AppplyUpDates更新到数据库的同时Delta中的数据也会被清空,注意最后的对话框。下面对数据进行修改,删除等操作,并查看Delta中的数据。

    效果图:

    **************************************************************************************

    具体操作:

    **************************************************************************************

    连接DBGrid1:

    DBGrid1.DataSource->DataSource1.DataSet->ClientDataSet1.ProviderName->DataSetProvider1.DataSet->

    SQLDataset1.SQLConnection->SQLConnection1具体数据库(这里连接的是oracle中的EMP表);

    SQLDataSet1.CommandText:=SELECT * FROM EMP;ClientDataSet1.Active:=true;

    DBNavigator1.DataSource->DataSource1;

    连接DBGrid2:

    DBGrid2.DataSource->DataSource2.DataSet->ClientDataSet2;

    将以上用到的控件放入一空白工程中,并按上面的设置连接好控件。

    **************************************************************************************

    相关CODE:

    **************************************************************************************

    procedure TForm3.Button1Click(Sender: TObject);
    begin
      // 删除和添加数据不触发AfterPost事件,手动赋值
      // 把ClientDataSet1的Delta中的数据给ClientDataSet2中的Data属性,让DBGrid2显示处理数据的细节
      ClientDataSet2.Data := ClientDataSet1.Delta;
      StatusBar1.Panels[0].Text := format('Delta数据计数:%d',
        [ClientDataSet2.RecordCount]);
    end;
    
    procedure TForm3.Button2Click(Sender: TObject);
    begin
        // 将修改的数据提交到数据库,0表示不允许发生错误
        ClientDataSet1.ApplyUpdates(0);
        ClientDataSet2.Data := ClientDataSet1.Delta;
    end;
    
    procedure TForm3.ClientDataSet1AfterPost(DataSet: TDataSet);
    begin
      // 把ClientDataSet1的Delta中的数据给ClientDataSet2中的Data属性,让DBGrid2显示处理数据的细节
      ClientDataSet2.Data := ClientDataSet1.Delta;
      StatusBar1.Panels[0].Text := format('Delta数据计数:%d',
        [ClientDataSet2.RecordCount]);
    end;

    https://www.cnblogs.com/sun998/p/6505540.html

  • 相关阅读:
    [知乎]20世纪初的军阀.
    Clover的简单使用
    影像工作站的数据库安装错误之Win7系统下pg服务无法启动
    屏蔽各大视频网站播放前15秒30秒广告
    电脑双显示器主分屏,巨鲨显示器不亮
    move 和 CopyMemory的区别
    The CompilerVersion constant identifies the internal version number of the Delphi compiler.
    Firemonkey的旁门左道[六]
    电够动力足——认识主板上的CPU供电模块
    delphi 枚举类型
  • 原文地址:https://www.cnblogs.com/fhweixin/p/13744176.html
Copyright © 2011-2022 走看看