[转载红鱼儿]kbmmw 开发点滴:There be must at least one field

There be must at least one field

用uniDAC+kbmMW+SQL Server做服务器,当客户端查询时,出现这个错误,在QQ群请教,一位朋友说,在服务器端查询不对,
憋了一天,最终,朋友改了TkbmMWUNIDACConnection,得以解决,原来是这样,如果uniDAC+SQL Server,则需要调用CoInitialize。
而kbmMWUNIDACConnection中没有调用。

代码如下,红色是需要增加的代码,当然仅对于MS SQL Server,对于其他数据库则不需要了:
procedure TkbmMWUNIDACConnection.InternalOpenConnection(ConnectionPool:TkbmMWCustomConnectionPool);
begin
     // Create new database connection using template.
     with TkbmMWUNIDACConnectionPool(ConnectionPool).FDBTemplate do
     begin
          FDatabase.Server := Server;//此处增加
          FDatabase.Database := Database;
          FDatabase.Username := UserName;
          FDatabase.Password := Password;
          FDatabase.LoginPrompt := False;
          FDatabase.ProviderName := ProviderName;
          FDatabase.Port := Port;//此处增加
          FDatabase.SpecificOptions.Assign(SpecificOptions);

          with TkbmMWUNIDACConnectionPool(ConnectionPool) do
               if Assigned(FOnSetupDBConnection) then FOnSetupDBConnection(self,FDatabase);
     end;

     if  FDatabase.ProviderName='SQL Server'  then
         CoInitialize(nil);

     FDatabase.Open;
end;

destructor TkbmMWUNIDACConnection.Destroy;
begin
   if FDatabase.ProviderName='SQL Server'  then
        CoUnInitialize;

   FDatabase.Free;

   inherited;
end;

进一步听说朋友说,这是第三方的人基于FB写的,根本没有测试SQLServer,也难怪!

初学kbmMW,当一见到这个错误时就蒙了,不知从哪下手,现在看来,出现这个错误,其核心是客户端的请求,
已经正确的发送到服务器,服务器端在执行查询时,出现问题,没有查询出结果,无法返回内容给客户端,也正如这个错误的含义:
“至少要有一个字段”。

时间: 2024-10-26 11:24:33

[转载红鱼儿]kbmmw 开发点滴:There be must at least one field的相关文章

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

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

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

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

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

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

[转载红鱼儿]kbmmw 开发点滴:解决QueryService重复查询问题

做一个简单的QueryService,在跟踪过程中发现,客户端一个查询,会被触发两次.怎么会这样,这严重影响服务器性能. 客户端的代码非常简单,就是执行一个SQL,通过QueryService返回结果:   kbmMWClientQuery2.Close;   kbmMWClientQuery2.Open; 于是利用服务器端的QueryService的事件OnQueryStatement进一步检查SQL的执行情况,把SQL写到Memo中: procedure TkbmMWQueryService

[转载红鱼儿]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数据集流化

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

[转载红鱼儿]kbmmw 开发点滴:kbmMWEventService的本质

在kbmMW创建服务向导中,有个"Eventoperated service",其描述信息:同TkbmMWSimpleService一样,就是公布了一个附加的事件,来控制客户端请求,取代了ProcessRequest.   看一下TkbmMWEventService代码,原来是这样:   1.TkbmMWEventService = class(TkbmMWSimpleService) 这个事件服务类是从TkbmSimpleService继承的,那么,就具有了SimpleService

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

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

[转载红鱼儿]kbmmw 开发点滴:TkbmMWLock用法

TStringList不是线程安全的,当我们在线程用到他是,要做保护.方法有两种,一种是用delphi自带的Critical,另外一种就是kbmMW为我们提供的TkbmMWLock类. 现在我们看看如何用TkbmMWLock为TStringList做线程安全: 1.基于TStringList声明自己的类: TThreadStringList=class(TStringList) 2.在该类中增加kbmMWLock实例 Private  FLock:TkbmMWLock; 在类的Create及De