1.多数据集的读取

A.取数SQL的配置,借用TStringList进行存储多个不同的取数SQL

B.DBA取数:  DBA.ReadMultipleDataSet(TStringList)

C.结果集的提取 DBA.GetResultDataSet(序位,FCDS); //序位从0开始,对应于TStringList的sql序位;

D.结果集的清理: DBA.ClearResultDataSets;

2.多数据集的提交

A.提交前的无效信息清理:  DBA.ClearWriteDataSets

B.添加需要提交的数据集:  DBA.AddWriteDataSet(表名,清理SQL,要提交的CDS);

C.写库: DBA.WriteMultipleDataSets;

-----------------------------------------------------------------------

经测:在多数据集提交时并未发现有任何地方标识关键字段值?

疑问:难道是在提交的过程中,通过表名取表结构,然后再来识别关键字?

那如果数据表未标识关键字,只是用户标识某个字段为关键字,如何执行?

3.Blob字段数据的处理

A.对于Blob字段内容->比如图片,文件等内容;先将其转为内存流后再做参数处理

FImgStream:=TMemoryStream.Create;

FImgStream.LoadFromFile(xxx); 或者其它的内存加载方式

B.借用DBA进行SQL处理

DBA.ParamParcel.Clear;

DBA.ParamParcel.PutStreamGoods(':XX',Stream);   //参数配置,前面加冒号,后面为形参   

//形参与字段名无实际关系,可一致,也可不一致

DBA.ExecuteSQL(SQL语句,是否有返回值,是否事务处理,返回接收变量);

** 在SQL语句中,配置的形参应该与Parcel中的形参一致

C.从DBA中取Blob字段信息

FImgStream:=TMemoryStream.Create;

TBlobField(CDS.fieldbyname('xx')).SaveToStream(FImgStream);     //将内容存到内存流中后,剩下的事情该怎么处理就怎么处理了

4.长耗时服务插件的回调业务

A.服务插件端:

a.创建接口对象:  Messager:=TAPIMessager.Create(InParcel);

b.从入口参数中提取回调对象来源信息==>需要客户端配合传入

TargetNodeId:=InParcel.GetAnsiStringGoods('ThisNodeId');

ConnectionId:=InParcel.GetInt64Goods('FromConnectionId');

c.实际业务处理(若业务中有客户端相关参数,直接从入参对象中提取)

d.回调结果返回

i: 创建返回参数,与常规插件一样,以QBParcel进行返回

ii:利用接口对象发送回调消息

Messager.CallbackToConnection(TargetNodeID,ConnectionID,返回参数);

iii:返回参数的释放 QBParcel.Free;

接口对象的释放 FreeAndNil(Messager);

B.客户端业务处理

a.参数配置:依据实际业务需要,配置传入参数

b.通过 TDllPlugin.AsyncRPC(插件名,插件访问密码,传入参数) 调用长耗时服务

c.提交后,业务处理完成.至于处理多久,处理完成并返回后的处理,则将由消息对象处理了;    

----------   

d.服务端返回长耗时业务后,回调的内容将由 TMsgReceiver 接收

** 接收处理事件为: OnCallBackMessage(MsgParcel:TQBParcel;DllFileName:String);

** 参数分别为服务端插件返回的参数及服务插件文件名

5.本地化业务插件处理

A: 客户端业务插件的调用,主要使用的是 TQBClientModule进行调用;

B: 参数传递 TQBClientModule.InPutParcel 进行处理,处理方法与常规情况下的QBParcel一致

C: 本地化插件调用: TQBClientModule.ExecuteTask('业务插件文件名称.dll');

D: 返回结果的提取与处理: 使用 TQBClientModule.OutPutParcel;

QB资料学习.01的更多相关文章

  1. spring学习(01)之IOC

    spring学习(01)之IOC IOC:控制反转——Spring通过一种称作控制反转(IOC)的技术促进了低耦合.当应用了IOC,一个对象依赖的其它对象会通过被动的方式传递进来,而不是这个对象自己创 ...

  2. Python学习--01入门

    Python学习--01入门 Python是一种解释型.面向对象.动态数据类型的高级程序设计语言.和PHP一样,它是后端开发语言. 如果有C语言.PHP语言.JAVA语言等其中一种语言的基础,学习Py ...

  3. Java虚拟机JVM学习01 流程概述

    Java虚拟机JVM学习01 流程概述 Java虚拟机与程序的生命周期 一个运行时的Java虚拟机(JVM)负责运行一个Java程序. 当启动一个Java程序时,一个虚拟机实例诞生:当程序关闭退出,这 ...

  4. Android Testing学习01 介绍 测试测什么 测试的类型

    Android Testing学习01 介绍 测试测什么 测试的类型 Android 测试 测什么 1.Activity的生命周期事件 应该测试Activity的生命周期事件处理. 如果你的Activ ...

  5. Java学习01

    Java学习01 第一章 1.JRE与JDK JDK(JAVA Develop Kit,JAVA开发工具包)提供了Java的开发环境和运行环境,主要用于开发JAVA程序,面向Java程序的开发者; J ...

  6. ThinkPhp学习01

    原文:ThinkPhp学习01 一.ThinkPHP的介绍           MVC  M - Model 模型                工作:负责数据的操作  V - View  视图(模板 ...

  7. 【iScroll源码学习01】准备阶段 - 叶小钗

    [iScroll源码学习01]准备阶段 - 叶小钗 时间 2013-12-29 18:41:00 博客园-原创精华区 原文  http://www.cnblogs.com/yexiaochai/p/3 ...

  8. JVM学习01:内存结构

    JVM学习01:内存结构 写在前面:本系列分享主要参考资料是  周志明老师的<深入理解Java虚拟机>第二版. 内存结构知识要点Xmind梳理 案例分析 分析1 package com.h ...

  9. webservice学习01:wsdl文档结构

    webservice学习01:wsdl文档结构 wsdl文档结构 WSDL文档示例 <wsdl:definitions xmlns:xsd="http://www.w3.org/200 ...

随机推荐

  1. javascript面向对象详解

    认识面向对象 1.面向对象中的概念 一切事物皆对象 对象具有封装和继承特性 信息隐藏 2.基本面向对象 3.函数构造器构造对象 深入了解面向对象 第一种书写格式 第二种书写格式

  2. 一个Demo学完Android中所有的服务(转)

    说明:这个例子实现了Android中常见的许多服务,下面是实现的截图 接下来,以源代码的方式分析这个例子   1.MainActivity--主界面 这个类主要是实现用户所看到的这个Activity, ...

  3. jsp 环境配置记录

    1. jdk,下载地址1 环境变量配置: 1)新建 JAVA_HOME 变量 . 变量值填写jdk的安装目录(本人是 C:\Java\jdk1.7.0) 2)  系统变量→寻找 Path 变量→编辑 ...

  4. Visual C++ 2008进行MySQL编程

    visual c++ 2008进行MySQL编程(ODBC) -- (一) 套装安装 visual c++ 2008进行MySQL编程(ODBC) --(二) CDatabase操作数据库 visua ...

  5. python—面向对象编程

    面向对象编程简单来说就是基于对 类 和 对象 的使用,所有的代码都是通过类和对象来实现的编程就是面向对象编程! 面向对象的三大特性:封装.继承.多态 首先创建一个类 #使用class创建一个Schoo ...

  6. mysql5.6版本开启数据库查询日志方法

    在my.ini中的[mysqld]下添加了以下两行代码: general_log=ONgeneral_log_file = c:/mysql.log 这个log文件是可以用文本编辑工具如editplu ...

  7. 理解GRUB2工作原理及配置选项与方法

    GRUB2是借鉴GRUB改写到更加安全强大到多系统引导程序,现在大部分较新的Linux发行版都是使用GRUB2作为引导程序的.GRUB2采用了模块化设计,使得GRUB2核心更加精炼,使用更加灵活,同时 ...

  8. [问题2014A08] 解答

    [问题2014A08] 解答 由假设知 \(f(A)=\mathrm{tr}(AA')\), 因此 \[f(PAP^{-1})=\mathrm{tr}(PAP^{-1}(P')^{-1}A'P')=\ ...

  9. Install-Package EntityFramework -version 5.0.0.0

    Install-Package EntityFramework -version 5.0.0.0

  10. 让下拉框中同时显示Key与Value

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...