QB资料学习.01
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的更多相关文章
- spring学习(01)之IOC
spring学习(01)之IOC IOC:控制反转——Spring通过一种称作控制反转(IOC)的技术促进了低耦合.当应用了IOC,一个对象依赖的其它对象会通过被动的方式传递进来,而不是这个对象自己创 ...
- Python学习--01入门
Python学习--01入门 Python是一种解释型.面向对象.动态数据类型的高级程序设计语言.和PHP一样,它是后端开发语言. 如果有C语言.PHP语言.JAVA语言等其中一种语言的基础,学习Py ...
- Java虚拟机JVM学习01 流程概述
Java虚拟机JVM学习01 流程概述 Java虚拟机与程序的生命周期 一个运行时的Java虚拟机(JVM)负责运行一个Java程序. 当启动一个Java程序时,一个虚拟机实例诞生:当程序关闭退出,这 ...
- Android Testing学习01 介绍 测试测什么 测试的类型
Android Testing学习01 介绍 测试测什么 测试的类型 Android 测试 测什么 1.Activity的生命周期事件 应该测试Activity的生命周期事件处理. 如果你的Activ ...
- Java学习01
Java学习01 第一章 1.JRE与JDK JDK(JAVA Develop Kit,JAVA开发工具包)提供了Java的开发环境和运行环境,主要用于开发JAVA程序,面向Java程序的开发者; J ...
- ThinkPhp学习01
原文:ThinkPhp学习01 一.ThinkPHP的介绍 MVC M - Model 模型 工作:负责数据的操作 V - View 视图(模板 ...
- 【iScroll源码学习01】准备阶段 - 叶小钗
[iScroll源码学习01]准备阶段 - 叶小钗 时间 2013-12-29 18:41:00 博客园-原创精华区 原文 http://www.cnblogs.com/yexiaochai/p/3 ...
- JVM学习01:内存结构
JVM学习01:内存结构 写在前面:本系列分享主要参考资料是 周志明老师的<深入理解Java虚拟机>第二版. 内存结构知识要点Xmind梳理 案例分析 分析1 package com.h ...
- webservice学习01:wsdl文档结构
webservice学习01:wsdl文档结构 wsdl文档结构 WSDL文档示例 <wsdl:definitions xmlns:xsd="http://www.w3.org/200 ...
随机推荐
- 。。。再战JQuery。。。
今天从学习JQurery的第一个函数开始!!! JQuery里面的show这个函数很不错,我很喜欢,他的使用方法如下:JQuery对象.show(speed,callback); speed你可以指定 ...
- 删除已经配置的类库和移除CocoaPods[转]
转自:http://blog.csdn.net/jymn_chen/article/details/19213601 引言 在使用CocoaPods(一)为项目配置第三方类库我们使用CocoaPods ...
- 高性能完成端口socket服务(IOCP)
1. Winsock IO模型之IOCP模型 来自csdn blog,版权声明:本文为博主原创文章,未经博主允许不得转载. 我这里记录下,不算转载吧 http://blog.csdn.net/lost ...
- db2常用命令(1)
DB2常用命令 1.启动实例(db2inst1):实例相当于informix中的服务 db2start 2.停止实例(db2inst1): db2stop 3.列出所有实例(db2inst1) d ...
- 03-组合逻辑电路设计之译码器——小梅哥FPGA设计思想与验证方法视频教程配套文档
芯航线——普利斯队长精心奉献 课程目标: 1. 再次熟悉Quartus II工程的建立以及完整的FPGA开发流程 2. 以译码器为例学会简单组合逻辑电路设计 实验平台:无 实验原理: 组合逻辑, ...
- Java虚拟机学习(4):对象内存分配与回收
对象优先在Eden上分配 大多数情况下,对象优先在新生代Eden区域中分配.当Eden内存区域没有足够的空间进行分配时,虚拟机将触发一次 Minor GC(新生代GC).Minor GC期间虚拟机将E ...
- cf 700 B Connecting Universities
题意:现在给以一棵$n$个结点的树,并给你$2k$个结点,现在要求你把这些节点互相配对,使得互相配对的节点之间的距离(路径上经过边的数目)之和最大.数据范围$1 \leq n \leq 200000, ...
- 自己写的java用jxl导出到excel工具
package com; import java.io.BufferedOutputStream; import java.io.File; import java.io.IOException; i ...
- 关于.net编译时目标生成平台
x86: 将程序集编译为由兼容 x86 的 32 位公共语言运行库运行. x64: 将程序集编译为由支持 AMD64 或 EM64T 指令集的计算机上的 64 位公共语言运行库运行. anycpu:( ...
- minicom 使用教程
因为现在电脑基本不配备串行接口,所以,usb转串口成为硬件调试时的必然选择.目前知道的,PL2303的驱动是有的,在dev下的名称是ttyUSB#. minicom,tkterm都是linux下应用比 ...