博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
OLEVARIANT的替代——FIREDAC的TFDJSONDataSets和TFDJSONDeltas
阅读量:6687 次
发布时间:2019-06-25

本文共 3139 字,大约阅读时间需要 10 分钟。

OLEVARIANT——这个COM的序列格式,也是DATASNAP已使用了20年的序列格式, 在20年以后的今天,终于有了它的替代者:FIREDAC的TFDJSONDataSets和TFDJSONDeltas,XE5 UPDATE2以上版本的DATASNAP的远程方法定义里面已经增加了这2种类型的支持。 FIREDAC的TFDCONNECTION尚没有“GENERATE DATASNAP CLIENT CLASSES”的项,感觉不方便,笔者测试的时候使用TSQLCONNECTION生成的客户端代理类, 易博龙稍后是否会提供?不得而知。
TFDJSONDataSets:数据集对象列表,可包含N个数据集对象,不论是单表查询或多表查询(主从表)的数据都用这种类型返回给客户端。
TFDJSONDeltas:客户端数据集的DELTA列表,可包含N个DELTA,不论是单表提交或多表提交(主从表)的数据都用这种类型提交给服务端。
为什么要有替代品? DATASNAP为了完全去除对COM的依存,为了能跨平台。 替代者的性能是否强于OLEVARIANT?
笔者未作测试对比,不敢断言。 下面分别给出服务端和客户端的演示代码。 一)服务器端代码演示 1)常量定义: const  sDepartment = 'Department';  sEmployees = 'Employees';

2)查询数据:

function TServerMethods1.GetDepartmentEmployees(const AID: string): TFDJSONDataSets; begin // Clear active so that query will reexecute. FDQueryDepartmentEmployees.Active := False; FDQueryDepartment.Active := False; FDQueryDepartment.Params[0].Value := AID; FDQueryDepartmentEmployees.Params[0].Value := AID; // Create dataset list Result := TFDJSONDataSets.Create; // Add departments dataset TFDJSONDataSetsWriter.ListAdd(Result, sDepartment, FDQueryDepartment); // Add employees dataset TFDJSONDataSetsWriter.ListAdd(Result, sEmployees, FDQueryDepartmentEmployees); end;
TFDJSONDataSets,FIREDAC的数据集列表对象,可返回多个数据集。 3)提交数据:
procedure TServerMethods1.ApplyChangesDepartmentEmployees(  const ADeltaList: TFDJSONDeltas); var LApply: IFDJSONDeltasApplyUpdates; begin // Create the apply object LApply := TFDJSONDeltasApplyUpdates.Create(ADeltaList); // Apply the department delta LApply.ApplyUpdates(sDepartment, FDQueryDepartment.Command); if LApply.Errors.Count = 0 then // If no errors, apply the employee delta LApply.ApplyUpdates(sEmployees, FDQueryDepartmentEmployees.Command); if LApply.Errors.Count > 0 then // Raise an exception if any errors. raise Exception.Create(LApply.Errors.Strings.Text); end; 二)客户端演示代码 1)查询数据:
procedure TForm2.GetDepartmentEmployees(const ADEPTNO: string); var LDataSetList: TFDJSONDataSets; LDataSet: TFDDataSet; begin LDataSetList := ClientModule1.ServerMethods1Client.GetDepartmentEmployees(ADEPTNO); // Get department dataset LDataSet := TFDJSONDataSetsReader.GetListValueByName(LDataSetList,sDepartment); // Update UI FDMemTableDepartment.Active := False; FDMemTableDepartment.AppendData(LDataSet); // Get employees dataset LDataSet := TFDJSONDataSetsReader.GetListValueByName(LDataSetList, sEmployees); // Update UI FDMemTableEmployee.Active := False; FDMemTableEmployee.AppendData(LDataSet); end; 2)提交数据:
function TForm2.GetDeltas: TFDJSONDeltas;begin // Post if editing if FDMemTableDepartment.State in dsEditModes then begin FDMemTableDepartment.Post; end; if FDMemTableEmployee.State in dsEditModes then begin FDMemTableEmployee.Post; end; // Create a delta list Result := TFDJSONDeltas.Create; // Add deltas TFDJSONDeltasWriter.ListAdd(Result, sEmployees, FDMemTableEmployee); TFDJSONDeltasWriter.ListAdd(Result, sDepartment, FDMemTableDepartment); end;
procedure TForm2.ApplyUpdates;var  LDeltaList: TFDJSONDeltas; begin LDeltaList := GetDeltas; // Call server method. Pass the delta list. ClientModule1.ServerMethods1Client.ApplyChangesDepartmentEmployees(LDeltaList); end; 注意: 服务端和客户端都要放置2个控件:  
 
 
 

转载地址:http://kthao.baihongyu.com/

你可能感兴趣的文章
培养自己的核心竞争力
查看>>
别样JAVA学习(六)继承下(2.3)异常下
查看>>
win10 配置 python3 + opencv3.2 + VideoCapture
查看>>
《JAVA与模式》之门面模式
查看>>
数据清洗小记(12):姓与名的提取
查看>>
Hadoop-1.2.1学习之Job创建和提交源码分析
查看>>
身份证验证
查看>>
K条最短路径算法(KSP, k-shortest pathes):Yen's Algorithm
查看>>
mysql last_insert_id() (转载)
查看>>
eclipse安装反编译插件jadclipse
查看>>
Change the Forwarding: RMT Architecture
查看>>
P1040 加分二叉树
查看>>
MySQL数据库安装(CentOS操作系统/tar.gz方式)
查看>>
Maven详解(八)------ 继承和聚合
查看>>
iOS开发ARC内存管理技术要点
查看>>
spring4.0之一:简介
查看>>
Control character in cookie value or attribute
查看>>
kali linux2.0安装vega
查看>>
我的第一个python web开发框架(6)——第一个Hello World
查看>>
Windows下swoole扩展的编译安装部署
查看>>