DataSnap Server中共享数据库连接
2011-08-26 23:59
204 查看
原文连接 http://www.delphifeeds.com/go/s/74909 google翻译并整理 当开发人员开始创建Delphi的DataSnap应用时很常见的数据库连接定义方式是每个数据模块建立一个连接。这样做将产生大量的数据库连接,并产生很多问题。 DelphiXe,提供了Session管理,更容易实现控制客户端连到服务器的数据库连接。客户端应用程序bu不会知道这些,服务器将完成所有的事情。 当我们创建一个DataSnap服务器时,最好的做法就是定义一个服务器容器(数据模块),其中包含DataSnap服务器组件和注册所有的服务器应用程序所需的类。在这个容器中,我们将定义一个负责处理服务器的数据库连接的方法。 作为一个例子,我已经实现了服务器容器上的一个的getConnection方法。这个方法负责 为连接池分配连接,这将有每一个客户端连接列表寻找,连接池里包含有每个客户端的连接。 private { Private declarations } ListofConnection : TDictionary; public function GetConnection : TSQLConnection; 当服务器收到来自新的客户端的连接到数据库的请求时,getConnection将创建一个新的连接并添加到 连接池清单。如果客户已经有了一个连接相关联,getConnection则只返回的一个SqlConnection实例 。连接池使用线程ID来控制每个客户端的唯一连接。如果您使用的DataSnap2010,你必须用GetThreadSession方法来实现这个功能。 function TServerContainer1.GetConnection: TSQLConnection; var dbconn : TSQLConnection; begin if ListofConnection.ContainsKey(TDSSessionManager.GetThreadSession.Id) then Result := ListofConnection[TDSSessionManager.GetThreadSession.Id] else begin dbconn := TSQLConnection.Create(nil); dbconn.Params.Clear; dbconn.LoadParamsOnConnect := true; dbconn.ConnectionName := 'DS Employee'; ListofConnection.Add(TDSSessionManager.GetThreadSession.Id, dbconn); Result := dbconn; end; 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事件是一个设置关联数据集的连接的好地方,可以使用下面的代码来设置。 procedure TServerContainer1.SetConnection(Conn: TSqlConnection); var i: integer; begin if Conn = nil then Conn := GetConnection; else Conn := Sender; for i := 0 to ComponentCount - 1 do if Components[i] is TSQLQuery then TSQLQuery(Components[i]).SQLConnection := Conn; end; 为了避免数据库连接泄漏,我们实现了DSServer的OnDisconnect事件。当客户端断开连接时这段持续将运行。 if GetConnection <> nil then GetConnection.Close; 完整源代码下载(下载后将后缀名改为zip) |
相关文章推荐
- datasnap 数据库连接
- DataNode连接错误Retrying connect to server
- oracle 两台机器做RAC负载均衡共享存储空间的数据库连接字符串
- DataSnap 2009 系列之一 (系统连接篇)
- 数据库组件 Hxj.Data (二十五)(数据库连接配置 - connectionStrings节点)
- Visual Studio 2008不能创建数据库连接出现:未能加载文件或程序集“Microsoft.SqlServer.Management.Sdk.Sfc, Version=10.0.0.0, Culture=neutral,PublicKeyToke
- C# 连接SQL Server数据库的几种方式--server+data source等方式
- MySQL 数据库连接失败 SQLSTATE[HY000] [2003] Can't connect to MySQL server on '127.0.0.1' (13)
- MS SQL Server 数据库连接字符串详解
- DataSnap 的连接事件顺序图
- 关于使用navicat for mysql在建立数据库连接时出现的2003 can't connect to mysql server on'localhost'(10038)问题
- 无法连接到数据库实例: ORA-12519: TNS: 没有找到适用的服务处理程序 (DBD ERROR: OCIServerAttach)。
- MsSQL server连接另外一台机器数据库,共享使用数据表的2种方法
- Chapter 1__1.6 Connecting to SQL Server Using Integrated Security from ASP.NET(集成安全连接数据库)
- 如何创建一个DataSnap Server
- 回答一位朋友的提问:在Delphi7下如何与DLL共享数据库连接
- 关于连接数据库失败、SQLServer xxxx 已成功与服务器建立连接,但是在登录前的握手期间发生错误。 (provider: SSL Provider, error: 0 - 等待的操作过时。)
- Delphi XE8中开发DataSnap程序常见问题和解决方法 (三)用TClientDataSet的“ProviderName”属性连接服务器时,无法找到服务器端的“DatasetProvier”
- windows 2008 server 安装VS2010 后无法无法访问数据库,提示“ORA-06413: 连接未打开”