• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

DelphiXEFireDac连接池

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

在开发Datasnap三层中,使用FireDac 连接  MSSQL数据库。

实现过程如下:

1、在ServerMethods 单元中放入 FDManager、FDPhysMSSQLDriverLink1、FDGUIxWaitCursor1等控件。

2、自定义过程:

  private
    var
      oParams: TStrings;

 

procedure TSrvMethods.SetupFDManager;    //加载数据库链接信息。
begin
  //*****初始化*****
  oParams := TStringList.Create;
  //********* 连接池
  oParams.Add('DriverID=MSSQL');
  //oParams.Add('CharacterSet=utf8');
  oParams.Add('Server=192.168.1.199');
  //oParams.Add('Port=3306');
  oParams.Add('Database=DSCSYS');
  oParams.Add('User_Name=sa');
  oParams.Add('Password=');
  //  毫秒
  oParams.Add('POOL_CleanupTimeout=36000');
  //  毫秒
  oParams.Add('POOL_ExpireTimeout=600000');
  //最多连接数
  oParams.Add('POOL_MaximumItems=60');
  oParams.Add('Pooled=True');
  //*******
  FDManager.Close;
  FDManager.AddConnectionDef('MSSQL_DSCSYS', 'MSSQL', oParams);
  try
    FDManager.Active := True;
  except
    on E: Exception do
    begin
      frmMain.Log.Error(e.Message, 'Error');
    end;
  end;
end;

3、在 Create 事件中:

procedure TSrvMethods.DSServerModuleCreate(Sender: TObject);
begin
  SetupFDManager;  // 加载数据库链接
end;

4、在查询使用中,动态生成FDConnection,设置Connected为true 就是  从连接池中取一个连接;具体代码如下

function TSrvMethods.QueryData(SQLStr: string): string;
var
  fdqry1: TFDQuery;
  mConn: TFDConnection;
begin
  try
    //***动态创建,用完释放;
    mConn := TFDConnection.Create(nil);
    mConn.ConnectionDefName := 'MSSQL_Conn';
    mConn.Connected := true;
    fdqry1 := TFDQuery.Create(nil);
    try
      fdqry1.Close;
      fdqry1.Connection := mConn;
      fdqry1.SQL.Clear;
      fdqry1.SQL.Add(SQLStr);
      fdqry1.Open();
      result := '{result:"OK",DataSet:}';
      frmMain.Log.Debug('ok', 'debug');
    finally
      fdqry1.Free;
      mConn.Free;
    end;
  except
    on E: Exception do
    begin
      result := '{Result:"失败 Error:' + e.message + '"}';
      frmMain.Log.Debug('NOok', 'debug');
    end;
  end;
end;

5、在关闭时候,释放创建的对象

procedure TSrvMethods.DSServerModuleDestroy(Sender: TObject);
begin
  oParams.Free;
end;

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Delphi中相对路径与绝对路径、系统环境变量等相关函数说明发布时间:2022-07-18
下一篇:
[转]delphixe6android屏幕操持常亮发布时间:2022-07-18
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap