热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

DIOCP开源项目DEMO(怎么样操作远程数据库)

经过两天时间的开源,感谢网友提出一些修改意见,特别是在XE中,做了一部分优化。可以在SVN中下载到最新的代码https:code.goog

经过两天时间的开源,感谢网友提出一些修改意见,特别是在XE中,做了一部分优化。

 

可以在SVN中下载到最新的代码

 

https://code.google.com/p/diocp/

今天做了一个操作数据库的演示<这里我拿出我在实际项目中操作数据库的方法&#xff0c;集成在Demo中>

 

操作数据库比较简单,分两部分功能&#xff0c;第一部分打开SQL

procedure TfrmMain.btnOpenSQLClick(Sender: TObject);
varlvJSonStream, lvRecvObject:TJsonStream;lvStream:TStream;lvData:AnsiString;l, j, x:Integer;
beginlvJSonStream :&#61; TJsonStream.Create;trylvJSonStream.JSon :&#61; SO();lvJSonStream.JSon.I[&#39;cmdIndex&#39;] :&#61; 1001; //打开一个SQL脚本&#xff0c;获取数据lvJSonStream.Json.S[&#39;sql&#39;] :&#61; mmoSQL.Lines.Text;FClientSocket.sendObject(lvJSonStream);finallylvJSonStream.Free;end;//读取数据lvRecvObject :&#61; TJsonStream.Create;tryFClientSocket.recvObject(lvRecvObject);if not lvRecvObject.getResult thenbeginraise Exception.Create(lvRecvObject.getResultMsg);end;SetLength(lvData, lvRecvObject.Stream.Size);lvRecvObject.Stream.Position :&#61; 0;lvRecvObject.Stream.ReadBuffer(lvData[1], lvRecvObject.Stream.Size);cdsMain.XMLData :&#61; lvData;finallylvRecvObject.Free;end;
end;

服务端ClientContext中的处理

procedure TClientContext.dataReceived(const pvDataObject:TObject);
varlvJsonStream:TJSonStream;lvFile:String;lvCmdIndex:Cardinal;lvXMLData, lvEncodeData:AnsiString;lvSQL:String;
beginlvJsonStream :&#61; TJSonStream(pvDataObject);lvCmdIndex :&#61; lvJsonStream.JSon.I[&#39;cmdIndex&#39;];//echo测试if lvCmdIndex&#61; 1000 thenbeginInterlockedIncrement(TesterINfo.__RecvTimes);//回写数据writeObject(lvJsonStream);end else if lvCmdIndex &#61; 1001 thenbegin //根据sql获取一个数据&#xff0c;放在Stream中trylvSQL :&#61; lvJsonStream.Json.S[&#39;sql&#39;];lvXMLData :&#61; dmMain.CDSProvider.QueryXMLData(lvSQL);lvJsonStream.Clear();lvJsonStream.Stream.WriteBuffer(lvXMLData[1], Length(lvXMLData));lvJsonStream.setResult(True);excepton e:Exception dobeginlvJsonStream.Clear();lvJsonStream.setResult(False);lvJsonStream.setResultMsg(e.Message);end;end;//回写数据writeObject(lvJsonStream);

 

保存数据用到一个非常好用的DLL

客户端:

procedure TfrmMain.btnPostClick(Sender: TObject);
varlvJSonStream, lvRecvObject:TJsonStream;lvStream:TStream;lvData:AnsiString;l, j, x:Integer;
beginif cdsMain.State in [dsInsert, dsEdit] then cdsMain.Post;if cdsMain.ChangeCount &#61; 0 thenbeginShowMessage(&#39;没有做任何修改!&#39;);exit;end;lvJSonStream :&#61; TJsonStream.Create;trylvJSonStream.JSon :&#61; SO();lvJSonStream.JSon.I[&#39;cmdIndex&#39;] :&#61; 1002; //打开一个SQL脚本&#xff0c;获取数据//打包修改记录with TCDSOperatorWrapper.createCDSEncode dobeginsetTableINfo(PAnsiChar(AnsiString(edtUpdateTable.Text)), PAnsiChar(AnsiString(edtKeyFields.Text)));setData(cdsMain.Data, cdsMain.Delta);//执行编码Execute;lvData :&#61; getPackageData;end;mmoData.Clear;mmoData.Lines.Add(lvData);lvJSonStream.Stream.Write(lvData[1], Length(lvData));FClientSocket.sendObject(lvJSonStream);finallylvJSonStream.Free;end;//读取数据lvRecvObject :&#61; TJsonStream.Create;tryFClientSocket.recvObject(lvRecvObject);if not lvRecvObject.getResult thenbeginraise Exception.Create(lvRecvObject.getResultMsg);end elsebeginShowMessage(&#39;保存成功!&#39;);end;finallylvRecvObject.Free;end;cdsMain.MergeChangeLog();end;

服务端:

if lvCmdIndex &#61; 1002 then //保存数据到熟客begintrylvJsonStream.Stream.Position :&#61; 0;SetLength(lvEncodeData, lvJSonStream.Stream.Size);lvJsonStream.Stream.ReadBuffer(lvEnCodeData[1], lvJSonStream.Stream.Size);dmMain.ExecuteApplyUpdate(lvEncodeData);lvJsonStream.Clear();lvJsonStream.setResult(True);excepton e:Exception dobeginlvJsonStream.Clear();lvJsonStream.setResult(False);lvJsonStream.setResultMsg(e.Message);end;end;//回写数据writeObject(lvJsonStream);end

 

 



推荐阅读
  • 利用Visual Basic开发SAP接口程序初探的方法与原理
    本文介绍了利用Visual Basic开发SAP接口程序的方法与原理,以及SAP R/3系统的特点和二次开发平台ABAP的使用。通过程序接口自动读取SAP R/3的数据表或视图,在外部进行处理和利用水晶报表等工具生成符合中国人习惯的报表样式。具体介绍了RFC调用的原理和模型,并强调本文主要不讨论SAP R/3函数的开发,而是针对使用SAP的公司的非ABAP开发人员提供了初步的接口程序开发指导。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • Android开发实现的计时器功能示例
    本文分享了Android开发实现的计时器功能示例,包括效果图、布局和按钮的使用。通过使用Chronometer控件,可以实现计时器功能。该示例适用于Android平台,供开发者参考。 ... [详细]
  • 移动端常用单位——rem的使用方法和注意事项
    本文介绍了移动端常用的单位rem的使用方法和注意事项,包括px、%、em、vw、vh等其他常用单位的比较。同时还介绍了如何通过JS获取视口宽度并动态调整rem的值,以适应不同设备的屏幕大小。此外,还提到了rem目前在移动端的主流地位。 ... [详细]
  • 本文介绍了Swing组件的用法,重点讲解了图标接口的定义和创建方法。图标接口用来将图标与各种组件相关联,可以是简单的绘画或使用磁盘上的GIF格式图像。文章详细介绍了图标接口的属性和绘制方法,并给出了一个菱形图标的实现示例。该示例可以配置图标的尺寸、颜色和填充状态。 ... [详细]
  • Android工程师面试准备及设计模式使用场景
    本文介绍了Android工程师面试准备的经验,包括面试流程和重点准备内容。同时,还介绍了建造者模式的使用场景,以及在Android开发中的具体应用。 ... [详细]
  • 图像因存在错误而无法显示 ... [详细]
  • 本文整理了Java中java.lang.NoSuchMethodError.getMessage()方法的一些代码示例,展示了NoSuchMethodErr ... [详细]
  • 使用freemaker生成Java代码的步骤及示例代码
    本文介绍了使用freemaker这个jar包生成Java代码的步骤,通过提前编辑好的模板,可以避免写重复代码。首先需要在springboot的pom.xml文件中加入freemaker的依赖包。然后编写模板,定义要生成的Java类的属性和方法。最后编写生成代码的类,通过加载模板文件和数据模型,生成Java代码文件。本文提供了示例代码,并展示了文件目录结构。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
author-avatar
90后的中老年人
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有