在三层结构中,TClientDataSet的地位是不可估量的,她的使用正确与否,是十分关键的,
本文从以下几个方面阐述她的使用,希望对你有所帮助.

1.动态索引
procedure TForm1.DBGrid1TitleClick(Column: TColumn);
begin
    if (not column.Field is Tblobfield) then//Tblobfield不能索引,二进制
       ClientDataSet1.IndexFieldNames:=column.Field.FieldName;
end;

2.多层结构中主从表的实现

设主表ClientDataSet1.packetrecord为-1,所有记录
   设从表ClientDataSet1.packetrecord为0,当前记录

 
3.Taggregates使用
(1)在字段编辑中add new field类型为aggregates
    后设置 Exp ression
    设置 Active:=true即可
    使用Dbedit的field为前者即可
 
(2)使用Aggergates属性add设计表达试 调用
  showmessage(floattostr(ClientDataSet1.Aggregates.Count));
  showmessage(ClientDataSet1.Aggregates.Items[0].Value);
4.在单层数据库中不要BDE

使用ClientDataSet代替table,使用ClientDataSet的loadfilename装入cds
   代替table的tablename的db或者dbf
   原来的程序改造方法:
   加一个ClientDataSet,使用右键assign locate data
   后savetofile,再loadfromfile,后删除table
   将原连table的datasource设为ClientDataSet
   唯一注意的是:要将midas.dll拷到system或者当前目录

5.三层结构的公文包的实现方法
   同时设定1:filename(*.cds)2.remote server

6.可以对data赋值(从另一个数据集取值)
    ClientDataSet2.Data:=ClientDataSet1.Data;
    ClientDataSet2.Open;
或者
   ClientDataSet2.CloneCursor(ClientDataSet1,true);
   ClientDataSet2.Open;

7.附加数据取得
   客户程序向应用服务器请求数据。如果TClientDataSet 的FetchOnDemand 属性设为True,
   客户程序会根据需要自动检索附加的数据包如BLOB字段的值或嵌套表的内容。
   否则,客户程序需要显式地调用GetNextPacket 才能获得这些附加的数据包。
   ClientDataSet的packetrecords设置一次取得的记录个数

8.ClientDataSet与服务器端query连接方法
(1)sql内容为空
        ClientDataSet1.Close;
        ClientDataSet1.CommandText:=edit1.Text;//即sql内容
        ClientDataSet1.Open;
        对于没有应用服务器设置filter 如:country like 'A%'
       filtered=true可实现sql功能
(2)有参数
      如服务端query的sql为
      select * from animals where name like :dd
     则:客户端ClientDataSet
var
   pm:Tparam;
begin
   ClientDataSet1.Close;
   ClientDataSet1.ProviderName:='DataSetProvider1';
   pm:=Tparam.Create(nil);
   pm.Name:='dd';
   pm.DataType:=ftString;
   ClientDataSet1.Params.Clear;
   ClientDataSet1.Params.AddParam(pm);
  ClientDataSet1.Params.ParamByName('dd').AsString:=edit1.Text ;
  ClientDataSet1.Open;
  pm.Free;
end;

9.数据的更新管理
(1)savepoint 保存目前为止数据状态,可以恢复到这个状态
var
   pp:integer;
begin
  pp:=ClientDataSet1.SavePoint;
  ClientDataSet1.Edit;
  ClientDataSet1.FieldByName('姓名').asstring:='古话';
  ClientDataSet1.Post;
  table1.Refresh;
end;
恢复点
  ClientDataSet1.SavePoint:=pp;

(2)cancel,RevertRecord
    取消对当前记录的修改,只适合没有post的,如果post,调用
    RevertRecord

(3)cancelupdate
    取消对数据库所有的修改

(4)UndoLastChange(boolean),changecount
    取消上一次的修改,可以实现连续撤消
   参数为true:光标到恢复处
   false:光标在当前位置不动
   changecount返回修改记录的次数,一个记录修改多次,返回只一次
   但UndoLastChange只撤消一次

10.可写的recno
     对于Ttable和Tquery的recno是只读的,而TClientDataSet的recno可读可写
     ClientDataSet1.recno:=5;是设第五个记录为当前记录

11.数据保存
     对于table使用post可更新数据
     而ClientDataSet1的post只更新内存数据,要更新服务器数据要使用
    ApplyUpdates(MaxErrors: Integer),他有一个参数,是允许发出错误的
    次数,-1表示无数次,使用simpleobjectbroker时常设为0,实现自动容错和负载平衡

DELPHI ClientData使用详解的更多相关文章

  1. delphi 资源文件详解

    delphi资源文件详解 一.引子: 现在的Windows应用程序几乎都使用图标.图片.光标.声音等,我们称它们为资源(Resource).最简单的使用资源的办法是把这些资源的源文件打入软件包,以方便 ...

  2. Delphi TStringHelper用法详解

    Delphi TStringHelper用法详解 (2013-08-27 22:45:42) 转载▼ 标签: delphi_xe5 it 分类: Delphi Delphi XE4的TStringHe ...

  3. delphi TStringList 用法详解

    转自: http://blog.163.com/you888@188/blog/static/67239619201472365642633/ delphi TStringList 用法详解 2014 ...

  4. Delphi中TApplication详解

    转自:http://blog.sina.com.cn/s/blog_4d6f55d90100bmv9.html TApplication是用于Delphi应用程序的类型,该类在单元forms中声明.T ...

  5. Delphi中TApplication详解(转仅供自己参考)

    转自:http://blog.sina.com.cn/s/blog_4d6f55d90100bmv9.html TApplication是用于Delphi应用程序的类型,该类在单元forms中声明.T ...

  6. 【delphi】关键字详解

    absolute {它使得你能够创建一个新变量, 并且该变量的起始地址与另一个变量相同.} var Str: ]; StrLen: Byte absolute Str; {这个声明指定了变量StrLe ...

  7. delphi 窗体透明详解TransparentColorValue,窗体透明控件不透明

    关于窗体透明的做法 来自:http://blog.csdn.net/shuaihj/article/details/8610343 关于窗体透明的做法 1.在Delphi中,设置窗体的AlphaBle ...

  8. Delphi Application.MessageBox详解

    引数:1. Text:要显示的讯息2. Caption:讯息视窗的标题列文字3. Flags:讯息旗标     3.1. 可指定讯息视窗上的图示     3.2. 可指定讯息视窗出现的按钮     3 ...

  9. Delphi IDHTTP用法详解(六种用法)

    一.IDHTTP的基本用法 IDHttp和WebBrowser一样,都可以实现抓取远端网页的功能,但是http方式更快.更节约资源,缺点是需要手动维护cook,连接等 IDHttp的创建,需要引入ID ...

随机推荐

  1. 《黑白团团》第九次团队作业:Beta冲刺与验收准备

    项目 内容 作业课程地址 任课教师首页链接 作业要求 团队项目 填写团队名称 黑白团团队 填写具体目标 认真负责,完成项目 GitHub链接 Scrum meeting导航 [Beta]Scrum m ...

  2. JS 时间差计算 XX秒前、XX小时前、XX天前

    //时间差 function GetTime(time) {//di作为一个变量传进来 //如果时间格式是正确的,那下面这一步转化时间格式就可以不用了 var dateBegin = new Date ...

  3. tsung压力测试环境部署详细步骤(内附安装包)

    操作系统: Redhat 6.3.Redhat6.5 .centos7.4(这些版本已验证过) tsung版本: tsung-1.6.0 下载地址: 链接: https://pan.baidu.com ...

  4. [Luogu] 维护序列

    https://www.luogu.org/problemnew/show/P2023 线段树双懒标记下放 #include <bits/stdc++.h> using namespace ...

  5. [Luogu] 引水入城

    https://www.luogu.org/problemnew/show/P1514 bfs + 线段覆盖 #include<bits/stdc++.h> using namespace ...

  6. 【luoguP1991】 无线通讯网--最小生成树

    题目描述 国防部计划用无线网络连接若干个边防哨所.2 种不同的通讯技术用来搭建无线网络: 每个边防哨所都要配备无线电收发器:有一些哨所还可以增配卫星电话. 任意两个配备了一条卫星电话线路的哨所(两边都 ...

  7. bbs--文章后台

    bbs--文章后台 需求分析 在个人文章后台中 1 有添加文章的接口 展示文章标题输入框 文本编辑框 标签 分类 选择框 提交 2 编辑文章的接口 页面与添加文章相同,就是把该文章的内容展示到文本编辑 ...

  8. 集合家族——ArrayList

    一.概述: ArrayList 是实现 List 接口的动态数组,所谓动态就是它的大小是可变的.实现了所有可选列表操作,并允许包括 null 在内的所有元素.除了实现 List 接口外,此类还提供一些 ...

  9. Django Admin中增加导出Excel功能

    参考: https://www.cnblogs.com/yoyo008/p/9232805.html 在使用Django Admin时, 对于列表我们有时需要提供数据导出功能, 如下图: 在Djang ...

  10. [Linux]ubuntu更改国内源

    转自: https://blog.csdn.net/qq_35451572/article/details/79516563 推荐快速更新国内源 https://blog.csdn.net/qq_35 ...