文档章节

TClientDataSet[17]: StatusFilter

涂孟超
 涂孟超
发布于 2014/09/26 15:34
字数 425
阅读 130
收藏 0

行业解决方案、产品招募中!想赚钱就来传!>>>


测试图:



测试代码:
unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, CheckLst, Grids, DBGrids, DB, DBClient;

type
  TForm1 = class(TForm)
    ClientDataSet1: TClientDataSet;
    DataSource1: TDataSource;
    DBGrid1: TDBGrid;
    ClientDataSet2: TClientDataSet;
    DataSource2: TDataSource;
    DBGrid2: TDBGrid;
    Button1: TButton;
    Button2: TButton;
    Button3: TButton;
    Button4: TButton;
    CheckListBox1: TCheckListBox;
    procedure Button4Click(Sender: TObject);
    procedure Button2Click(Sender: TObject);
    procedure Button3Click(Sender: TObject);
    procedure FormCreate(Sender: TObject);
    procedure Button1Click(Sender: TObject);
    procedure CheckListBox1Click(Sender: TObject);
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

procedure TForm1.FormCreate(Sender: TObject);
begin
  DBGrid1.DataSource := DataSource1;
  DataSource1.DataSet := ClientDataSet1;

  DBGrid2.DataSource := DataSource2;
  DataSource2.DataSet := ClientDataSet2;

  with ClientDataSet1 do begin
    FieldDefs.Add('Text', ftString, 12);
    FieldDefs.Add('Num', ftInteger);
    CreateDataSet;
    AppendRecord(['XXX', 111]);
    AppendRecord(['YYY', 222]);
    AppendRecord(['ZZZ', 333]);
  end;
  ClientDataSet2.CloneCursor(ClientDataSet1, False);

  CheckListBox1.Items.CommaText := 'usUnmodified, usModified, usInserted, usDeleted';
end;

procedure TForm1.CheckListBox1Click(Sender: TObject);
var
  i: Integer;
begin
  ClientDataSet2.StatusFilter := [];
  for i := 0 to CheckListBox1.Count - 1 do
  begin
    if CheckListBox1.Checked[i] then
      ClientDataSet2.StatusFilter := ClientDataSet1.StatusFilter + [TUpdateStatus(i)]
  end;
end;

procedure TForm1.Button1Click(Sender: TObject);
begin
  ClientDataSet1.Append;
end;

procedure TForm1.Button2Click(Sender: TObject);
begin
  ClientDataSet1.Delete;
end;

procedure TForm1.Button4Click(Sender: TObject);
begin
  ClientDataSet1.MergeChangeLog;
end;

procedure TForm1.Button3Click(Sender: TObject);
begin
  ClientDataSet1.UndoLastChange(True);
end;

end.

 
 
 
 
 

 

 

  

测试窗体:
object Form1: TForm1
  Left = 0
  Top = 0
  Caption = 'Form1'
  ClientHeight = 231
  ClientWidth = 496
  Color = clBtnFace
  Font.Charset = DEFAULT_CHARSET
  Font.Color = clWindowText
  Font.Height = -11
  Font.Name = 'Tahoma'
  Font.Style = []
  OldCreateOrder = False
  OnCreate = FormCreate
  PixelsPerInch = 96
  TextHeight = 13
  object ClientDataSet1: TClientDataSet
    Aggregates = <>
    Params = <>
    Left = 64
    Top = 64
  end
  object DataSource1: TDataSource
    DataSet = ClientDataSet1
    Left = 64
    Top = 120
  end
  object DBGrid1: TDBGrid
    Left = 0
    Top = 0
    Width = 193
    Height = 231
    Align = alLeft
    DataSource = DataSource1
    TabOrder = 0
    TitleFont.Charset = DEFAULT_CHARSET
    TitleFont.Color = clWindowText
    TitleFont.Height = -11
    TitleFont.Name = 'Tahoma'
    TitleFont.Style = []
  end
  object ClientDataSet2: TClientDataSet
    Aggregates = <>
    Params = <>
    Left = 344
    Top = 80
  end
  object DataSource2: TDataSource
    Left = 344
    Top = 136
  end
  object DBGrid2: TDBGrid
    Left = 302
    Top = 0
    Width = 194
    Height = 231
    Align = alRight
    TabOrder = 5
    TitleFont.Charset = DEFAULT_CHARSET
    TitleFont.Color = clWindowText
    TitleFont.Height = -11
    TitleFont.Name = 'Tahoma'
    TitleFont.Style = []
  end
  object Button1: TButton
    Left = 199
    Top = 8
    Width = 97
    Height = 25
    Caption = 'Append'
    TabOrder = 4
    OnClick = Button1Click
  end
  object Button2: TButton
    Left = 199
    Top = 39
    Width = 97
    Height = 25
    Caption = 'Delete'
    TabOrder = 2
    OnClick = Button2Click
  end
  object Button3: TButton
    Left = 199
    Top = 78
    Width = 97
    Height = 25
    Caption = 'UndoLastChange'
    TabOrder = 3
    OnClick = Button3Click
  end
  object Button4: TButton
    Left = 199
    Top = 109
    Width = 97
    Height = 25
    Caption = 'MergeChangeLog'
    TabOrder = 1
    OnClick = Button4Click
  end
  object CheckListBox1: TCheckListBox
    Left = 199
    Top = 152
    Width = 97
    Height = 70
    ItemHeight = 13
    TabOrder = 6
    OnClick = CheckListBox1Click
  end
end

 
 
 
 
 

 

 

  
涂孟超
粉丝 13
博文 2011
码字总数 14107
作品 0
深圳
程序员
私信 提问
加载中
请先登录后再评论。
CDH5: 使用parcels配置lzo

一、Parcel 部署步骤 1 下载: 首先需要下载 Parcel。下载完成后,Parcel 将驻留在 Cloudera Manager 主机的本地目录中。 2 分配: Parcel 下载后,将分配到群集中的所有主机上并解压缩。 3 激...

cloud-coder
2014/07/01
6.8K
1
CentOS 7.2基于Kubernetes部署简单应用示例

上一篇我们部署了Kubernetes集群,接下来会在这个集群上运行一个简单的应用。 以下面的图来安装一个简单的静态内容的nginx应用: 首先,我们用复制器启动一个2个备份的nginx Pod。然后在前面...

壬癸甲乙
2015/12/30
2K
5
17个新手常见Python运行时错误

当初学 Python 时,想要弄懂 Python 的错误信息的含义可能有点复杂。这里列出了常见的的一些让你程序 crash 的运行时错误。 1)忘记在 if , elif , else , for , while , class ,def 声明末尾...

铁扇公主1
2017/04/03
171
0
Python总结的一些小知识点【1】

1、正则表达式替换 目标: 将字符串line中的 overview.gif 替换成其他字符串 复制代码代码如下: >>> line = '' >>> mo=re.compile(r'(?<=SRC=)"([w+.]+)"',re.I) >>> mo.sub(r'"1"',line) ' ......

铁扇公主1
2017/04/11
123
0
NORDIC和TI 蓝牙4.0芯片,现在价格优惠啦,以下型号实单可以谈

当你看到以下型号有变动,对的你没有看错,价格实惠 CC2541F256RHAR 45k 16+ 原装现货 实单价格来谈 CC2540F256RHAR 150k 16+ 原装现货 实单价格可以来谈 CC2530F256RHAR 50k 17+ 原装现货 ...

sale60
2017/07/10
54
0

没有更多内容

加载失败,请刷新页面

加载更多

C#中的9个“黑魔法”与“骚操作”

点击蓝字“ 大白技术控 ”关注我哟 加个“星标★”,每日良时,好文必达! 我们知道C#是非常先进的语言,因为是它很有远见的"语法糖"。这些"语法糖"有时过于好用,导致有人觉得它是C#编译器写...

大白技术控
04/06
0
0
npm

package.json(nmp install -y) { "name": "timer", //项目名 "version": "1.0.0", //版本号 "description": "A cool timer", //描述 "main": "timer.js", //项目主入口......

长臂猿猴
15分钟前
11
0
vpp系列6-DNAT

前置 上一篇讲到SNAT,这篇试验DNAT DNAT 首先在host机器上安装nginx apt-get install nginx 确认服务启动 DNAT配置 # 设置DNat,将ethvpp-pub口的tcp 80端口号映射到本地10.10.5.2的80端口号...

messud4312
18分钟前
16
0
Go语言对接USDT-TRC20【TronTool】

TronTool.Go开发包适用于为Go应用快速增加对Tron/USDT-TRC20数字资产的支持能力,即支持使用自有Tron区块链节点的应用场景,也支持基于Tron官方公共API服务的轻量级部署场景。官方下载地址:...

区块链教程
19分钟前
13
0
如何避免JSP文件中的Java代码? - How to avoid Java code in JSP files?

问题: I'm new to Java EE and I know that something like the following three lines 我是Java EE的新手,我知道类似以下三行 <%= x+1 %><%= request.getParameter("name") %><%! count......

fyin1314
20分钟前
11
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部