4

我正在启动一个带有登录表单的应用程序。

在用户写入登录数据之前,我想谨慎地连接到 SQL 服务器。

问题是,当我的连接速度很慢或到服务器的路径错误时,应用程序正在寻找服务器或尝试连接,此时应用程序没有响应。

对于连接,我使用以下过程:

//-- SQL connect --//
procedure TSql.Connect;
var
  DriverId: String;
  i: Byte;
begin
  try
    Screen.Cursor:=crAppStart;

    //connection DriverName
    DriverId:=Server[FServerType].DriverId;
    FConnection.DriverName:=DriverId;

    //connection Params
    FConnection.Params.Clear;
    FConnection.Params.Add('DriverID='+DriverId); //mandatory
    if FConnString.Count>0 then
       for i := 0 to FConnString.Count-1 do FConnection.Params.Add(FConnString.Strings[i]);

    try
      FConnection.Open;
      FQuery.Connection:=FConnection;
    except
      on E : Exception do ShowError(_('Connection could not be established!'),E);
    end;
  finally
    Screen.Cursor:=crdefault;
  end;
end;

请帮助我就如何做到这一点提出一些建议。我已经阅读了有关线程的内容,Application.ProcessMessages但我没有成功使其顺利运行。

4

1 回答 1

2

创建一个新线程,并在上面做你需要的一切,这不会挂起主窗体,用户将看不到任何你可以在这里看到类似功能的东西

于 2014-06-30T19:46:10.383 回答