


全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
多层结构中必不可少件TClientDataSet的全面剖析在三层结构中,TClientDataSet的地位是不可估量的,她的使用正确与否,是十分关键的,本文从以下几个方面阐述她的使用,希望对你有所帮助.1.动态索引procedure TForm1.DBGrid1TitleClick(Column: TColumn);beginif (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 后设置expression(表达试) 设置active:=true即可 使用dbedit的field为前者即可(2)使用Aggergates属性add设计表达试 调用showmessage(floattostr(ClientDataSet1.Aggregates.Count);showmessage(ClientDataSet1.Aggregates.Items0.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 server6.可以对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可更新数据 而ClientDa
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 林山流转合同范本
- 股权价转让合同范本
- 理财公司兼职合同范本
- 炼油设备租用合同范本
- 个人车辆借用合同范本
- 江苏防水维修合同范本
- 工程降水井合同范本
- 摄影器材采购合同范本
- 正式建筑合同范本
- 青皮核桃销售合同范本
- 2025年北京高端商务车租赁及全程安全保障合同
- 2025年智能家居产业互联互通标准与产业发展现状及问题研究报告
- 2025年领导干部政治理论知识必考题库及答案
- 2025年提取公积金租房合同范本
- 2025高职单招考试题(附答案)
- 储能系统运维安全手册
- GB/T 45997-2025科技成果五元价值评估指南
- 转让网约车合同协议书范本
- 医院 捐赠协议书
- 小学食堂供餐管理方案(3篇)
- 湖北省武汉市武昌区重点名校2026届中考语文全真模拟试题含解析
评论
0/150
提交评论