datasnap连接池使用

   当开发人员开始创建Delphi的DataSnap应用时很常见的数据库连接定义方式是每个数据模块建立一个连接。这样做将产生大量的数据库连接,并产生很多问题。从Delphi XE开始,EMB提供了Session管理,更容易实现控制客户端连到服务器的数据库连接。客户端应用程序不会知道这些,服务器将完成所有的事情。
当我们创建一个DataSnap服务器时,最好的做法就是定义一个服务器容器(或数据模块)如ServerContainer模块,其中包含DataSnap服务器组件和注册所有的服务器应用程序所需的类。在这个容器中,我们将定义一个负责处理服务器的数据库连接的方法。
作为一个例子,我已经实现了服务器容器上的一个的getConnection方法。这个方法负责为连接池分配连接,这将有每一个客户端连接列表寻找,连接池里包含有每个客户端的连接,当然更简化一点我们可以直接在其上放置一个Connection控件,而不是放置在ServerMethods单元中,从而达到共享数据库连接池的目的。
[delphi]  view plain  copy
 print ?
  1. private  
  2.  { Private declarations }  
  3.  ListofConnection : TDictionary;  
  4. ublic  
  5.  function GetConnection : TSQLConnection;  

    当服务器收到来自新的客户端的连接到数据库的请求时,getConnection将创建一个新的连接并添加到连接池清单。如果客户已经有了一个连接相关联,getConnection则只返回的一个SqlConnection实例。连接池使用线程ID来控制每个客户端的唯一连接。如果您使用的DataSnap 2010版本,你必须用GetThreadSession方法来实现这个功能。
[delphi]  view plain  copy
 print ?
  1. function TServerContainer1.GetConnection: TSQLConnection;  
  2. var  
  3.   dbconn : TSQLConnection;  
  4. begin  
  5.   if ListofConnection.ContainsKey(TDSSessionManager.GetThreadSession.Id) then  
  6.      Result := ListofConnection[TDSSessionManager.GetThreadSession.Id]  
  7.   else  
  8.   begin  
  9.     dbconn := TSQLConnection.Create(nil);  
  10.     dbconn.Params.Clear;  
  11.     dbconn.LoadParamsOnConnect := true;  
  12.     dbconn.ConnectionName := 'DS Employee';  
  13.     ListofConnection.Add(TDSSessionManager.GetThreadSession.Id, dbconn);  
  14.     Result := dbconn;  
  15.   end;  
  16. end;  

    连接定义后,我们需要更新所有数据集使用此连接,这样服务器的所有方法包括create 和运行时的SQL查询都将要调用getConnection方法。

If you are using the VCL Data components (TSQLQuery, TSQLStoredProc, etc…) on your Server DataModules, the onCreate event is a good place to associate the DataSets with the connection, using the following code.

    如果您在服务器上DataModules使用VCL的数据组件(TSQLQuery,TSQLStoredProc等...),
在OnCreate事件是一个设置关联数据集的连接的好地方,可以使用下面的代码来设置。
[delphi]  view plain  copy
 print ?
  1. procedure TServerContainer1.SetConnection(Conn: TSqlConnection);  
  2. var  
  3.   i: integer;  
  4. begin  
  5.   if Conn = nil then  
  6.      Conn := GetConnection;  
  7.   else  
  8.     Conn := Sender;  
  9.   for i := 0 to ComponentCount - 1 do  
  10.     if Components is TSQLQuery then  
  11.        TSQLQuery(Components).SQLConnection := Conn;  
  12. end;  

    为了避免数据库连接泄漏,我们实现了DSServer的OnDisconnect事件。当客户端断开连接时这段持续将运行。
[delphi]  view plain  copy
 print ?
  1. if GetConnection <> nil then  
  2.    GetConnection.Close;  

    当然我们也可以用此方法实现数据集和TDataSetProvider的池化处理。


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Delphi DataSnap数据池是一种在Delphi环境下使用的数据库连接和数据存储技术。它可以帮助开发者在分布式应用程序中通过网络进行数据交互。 DataSnap 数据池的核心概念是数据模块(Data Module),它提供了与数据库的连接和查询功能。数据模块可以包含多个数据集(DataSet),可以执行查询、插入、更新和删除操作。数据模块还具有数据源(DataSource)和数据集提供者(Provider)的功能,可以将数据源与数据集提供者进行绑定,从而将数据源的数据传输到客户端应用程序。 使用 Delphi DataSnap 数据池,开发者可以通过远程数据集(RemoteDataSet)实现跨网络的数据访问。这种跨网络的数据交互是通过 DataSnap 服务器和客户端进行的。服务器端使用数据连接(Data Connection)建立与数据库的连接,客户端通过 DataSnap 连接器(DataSnap Connector)连接到服务器,并获取或更新数据。 Delphi DataSnap数据池的优点是可以支持多种数据源(如数据库、文件和Web服务等),可以实现高效的数据交互。同时,它还具有安全性和性能优化的特性。开发者可以通过配置和设置来控制数据传输的安全性和性能。这使得开发分布式应用程序更加灵活和高效。 总之,Delphi DataSnap数据池是一种强大的数据交互技术,能够帮助开发者实现分布式应用程序中的数据存储和访问。它是Delphi环境下开发分布式应用程序的重要工具之一。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值