[转载红鱼儿]kbmmw 开发点滴:kbmmW服务端事务控制

   关于kbmMW的事务控制,前文已经在客户端实现,通过kbmMWClientTransaction来控制多个数据集的提交,在客户端提交多数据集,实际上,是在客户端实现业务逻辑,并通过一个事务来完成数据处理,这是违反多层架构的做法,实际项目中,需要在服务端,往往是利用多个数据集进行业务处理,并且用事务来控制,那我们该怎么办呢?换句话说,如何在服务实现事务的控制。

kbmMW在服务端,如同在客户端一样,为我们提供了方便的机制来处理事务。
下面的代码,转自kbmMW的新闻组:

var
  tx: TkbmMWTransaction;
begin
 tx := TkbmMWTransaction.Create;
 try
   try
     tx.AddConnection(SrvCore.mwDbConPool.GetBestConnection);
     tx.StartTransaction;
     qQueryDel.Execute(tx);//if exec type statement
     qQueryDel.Resolve(tx);//if resolve
      qAnotherQuery.Resolve(tx);
     tx.CommitTransaction;
      Result := true;
   except
     tx.RollbackTransaction;
     raise;
   end;
 finally
   tx.ReleaseConnections;
   tx.Free;
 end;
end;
通过上面的代码,可以看到,kbmMW提供了TkbmMWTransaction,来控制服务端的事务控制,用法简洁,想必一看也就清楚了。
时间: 2024-10-26 11:24:22

[转载红鱼儿]kbmmw 开发点滴:kbmmW服务端事务控制的相关文章

[转载红鱼儿]kbmmw 开发点滴:kbmMW在事务中批量执行SQL

按客户端使用事务更新多个表数据到kbmMW服务器,使用TkbmMWClientTransactionResolve, 可以一次性提交多个修改的数据集到服务器端,服务器利用事务来执行数据的更新,成功,提交事务,不成功,则Rollback事务.在实际开发中,可能遇到 在更新数据集的同时,还要执行单独的SQL,处理业务逻辑.方法是:用一个单独的TkbmMWClientQuery来执行.具体用法: kbmMWClietnQuery3.Query.Text:='Update T1 Set F2=1 whe

[转载红鱼儿]kbmmw 开发点滴:kbmMW数据集流化

kbmMW提供了QueryService,供我们在客户端象传统数据库应用一样,直接利用ClientQuery做SQL查询,以及提交,并且能够在客 户端以事务的方式提交多个数据集,应该说,QueryService为我们提供了非常好的便利,快速将两层应用转为多层应用,如果用过ASTA,就会发 现,QueryService在对两层应用的转化上,要比其实现的更完美,层次更清晰.但在实际项目中,如果考虑应用服务器对多平台的支持以及业务逻辑的 集中实现,那么仅仅使用QueryService是不够的,我们可能

[转载红鱼儿]kbmmw 开发点滴:kbmMW缓存机制

kbmMW提供了稳顾机制,分为服务端的Cache及客户端的Cache.以客户端为例,当客户端发出相同的数据查询请求时,kbmMW会在客户端的Cache中查找,如果找到,则不再向服务器请求数据. 为了启用一个ClientQuery使用稳存,首先要设置其以下两个属性: kbmMWClientQuery.Cached:=True;//打开数据集的稳存 kbmMWClientQuery.CacheFlags: mwcfDontAge - 缓存的内容不过期,一直在Cache保留 mwcfDontGarba

[转载红鱼儿]kbmmw 开发点滴:kbmMW客户端提交事务的现场处理

多层应用中的事务处理,是必须的,如果处理不好,就会出现各种数据不同步的现象,无法投入使用.以前用ASTA实现的多层应用,是在客户端利用ASTA机 制,将要提交的数据集.执行的SQL及SP,统统生成到一个脚本中,在ASTA是TAstaParamList,然后一次性提交到服务器,在服务器端在执 行这个脚本时,开启事务,执行脚本,如果成功则Commit,失败则Rollback. kbmMW提供了更好的事务处理机制,即可以在服务器端做事务处理(TkbmMWTransactionResolve)也可以在客

[转载红鱼儿]kbmmw 开发点滴:kbmMW默认服务

这两天,用xalion的入门文章学习kbmMW的使用,当用kbmMW向导生成一个Service后,需要注册到kbmMWServer中,具体的方法在生成的Service中已经有说明: // INSTRUCTIONS FOR REGISTRATION/USAGE // ----------------------------------- // Please update the uses clause of the datamodule/form the TkbmMWServer is place

[转载红鱼儿]kbmmw 开发点滴:kbmMW:Unknown property:indexes

利用kbmMW的QueryServices,对数据集进行提交,当改用JSON格式时,客户端提交时,会产生这个错误,明明已经更新数据库,也产生这个错误!如果换成Bin格式,则正常. 能过查看kbmMWJSONStreamFormat单元,问题产生在这行代码:nIndexDefs:=nDefs.AsArray['indexes']; 可以这样理解: 客户端提交数据后,服务器会返回一个错误结果数据集,不管有无错误,都要返回这个结果集.客户端会把这个数据集加载到 ClientQuery.ErrorTab

ubuntu下安装 gSOAP 用于C/C++开发web service服务端与客户端

昨天在ubuntu下进行安装gSOAP,费了很多时间,没成功,今天又来找了大量教程资料,终于一次成功,这里写下自己的安装步骤和方法,供大家参考. 首先下载gsoap,我下载的是gsoap-2.8.1.zip 用unzip gsoap-2.8.1.zip命令解压缩,会解压生成gsoap-2.8文件夹. cd gsoap-2.8   在安装之前需要先安装一些编译工具.     安装编译工具: $sudo apt-get install build-essential 为了成功编译gSOAP,您需要安

实现Apache XML-RPC开发客户端及服务端Java代码

本文将会首先介绍一下 XML-RPC 协议规范,然后介绍如何实现 Apache XML-RPC 开发客户端及服务端 Java 代码.最后对 Apache XML-RPC 的高级特性进行了介绍. 在新技术.新概念甚至新思维层见叠出的 IT 行业,XML-RPC 绝对不是最新的热门技术,但它自诞生之日起,一直在 IT 行业占有一席之地.XML-RPC 具有简单且易于实现,可以高效跨越不同的软硬件平台上应用系统等优点.相对于庞大.复杂的分布式计算机制,它一直是中小型应用的最佳选择之一.比如,流行于软件

[转载红鱼儿]kbmmw 开发点滴:Authorization failed.

开始利用kbmmw实作项目,第一件事就是为的服务端加用户的认证.如果客户端发来的请求无法在服务器端通过认证,即客户端认证失败,会在客户端弹出一个错误提示窗口:Authorization failed.总不能让用户看到这样的提示信息,得想办法,截获这样的错误,并给出自己的提示.没想到,费了一翻周拆,最终发现,kbmMW没有提供机制来处理这样的问题. 先看看服务器在哪里处理这样的错误: 单元:kwmMWServer 方法:procedure TkbmMWServer.InternalServeMes