偶是采用这样种形式做的,建立一个ini文件,如果第一次登录,则要求输入数据库服务地址,(可再要求输入用户名和密码),这样后保存进一个ini文件中,实现连接.
unit connectdata;interfaceuses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, Buttons,inifiles, ExtCtrls;type
    TNetResourceArray = ^TNetResource;//网络类型的数组type
  TForm49 = class(TForm)
    Panel1: TPanel;
    Label1: TLabel;
    Label2: TLabel;
    Label3: TLabel;
    ComboBox1: TComboBox;
    ComboBox2: TComboBox;
    BitBtn1: TBitBtn;
    BitBtn2: TBitBtn;
    Panel2: TPanel;
    BitBtn3: TBitBtn;
    Label4: TLabel;
    Label5: TLabel;
    Label6: TLabel;
    procedure ComboBox1DropDown(Sender: TObject);
    procedure ComboBox2DropDown(Sender: TObject);
    procedure BitBtn1Click(Sender: TObject);
    procedure FormClose(Sender: TObject; var Action: TCloseAction);
    procedure BitBtn3Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;var
  Form49: TForm49;
  Function GetServerList( var List : TStringList ) : Boolean;implementationuses main, datamodule;{$R *.dfm}//列举出整个网络中的工作组名称,返回值为TRUE表示执行成功,
//参数List中返回服务器(工作组)的名称
Function GetServerList( var List : TStringList ) : Boolean;
Var
    NetResource : TNetResource;
    Buf : Pointer;
    Count,BufSize,Res : DWORD;
    lphEnum : THandle;
    p:TNetResourceArray;
    i,j : SmallInt;
    NetworkTypeList : TList;
Begin
    Result := False;
    NetworkTypeList := TList.Create;
    List.Clear;
    //获取整个网络中的文件资源的句柄,lphEnum为返回名柄
    Res:= WNetOpenEnum( RESOURCE_GLOBALNET, RESOURCETYPE_DISK,
    RESOURCEUSAGE_CONTAINER, Nil,lphEnum);
    If Res <> NO_ERROR Then exit;//Raise Exception(Res);//执行失败
    //获取整个网络中的网络类型信息
    Count := $FFFFFFFF;//不限资源数目
    BufSize := 8192;//缓冲区大小设置为8K
    GetMem(Buf, BufSize);//申请内存,用于获取工作组信息
    Res := WNetEnumResource(lphEnum, Count, Pointer(Buf),BufSize);
    If (Res=ERROR_NO_MORE_ITEMS )//资源列举完毕
        or (Res <> NO_ERROR )//执行失败
        Then Exit;
    P:=TNetResourceArray(Buf);
    For I := 0 To Count - 1 Do//记录各个网络类型的信息
    Begin
        NetworkTypeList.Add(p);
        Inc(P);
    End;    //WNetCloseEnum关闭一个列举句柄
    Res := WNetCloseEnum(lphEnum);//关闭一次列举
    If Res <> NO_ERROR Then exit;    For J := 0 To NetworkTypeList.Count-1 Do //列出各个网络类型中的所有工作组名称
    Begin//列出一个网络类型中的所有工作组名称
        NetResource := TNetResource(NetworkTypeList.Items[J]^);//网络类型信息
        //获取某个网络类型的文件资源的句柄,NetResource为网络类型信息,lphEnum为返回名柄
        Res := WNetOpenEnum(RESOURCE_GLOBALNET, RESOURCETYPE_DISK,
        RESOURCEUSAGE_CONTAINER, @NetResource,lphEnum);
        If Res <> NO_ERROR Then break;//执行失败        While true Do//列举一个网络类型的所有工作组的信息
        Begin
            Count := $FFFFFFFF;//不限资源数目
            BufSize := 8192;//缓冲区大小设置为8K
            GetMem(Buf, BufSize);//申请内存,用于获取工作组信息
            //获取一个网络类型的文件资源信息,
            Res := WNetEnumResource(lphEnum, Count, Pointer(Buf),BufSize);
            If ( Res = ERROR_NO_MORE_ITEMS ) //资源列举完毕
                or (Res <> NO_ERROR) //执行失败
                then break;
            P := TNetResourceArray(Buf);
            For I := 0 To Count - 1 Do//列举各个工作组的信息
            Begin
                List.Add( StrPAS( P^.lpRemoteName ));//取得一个工作组的名称
                Inc(P);
            End;
        End;
        Res := WNetCloseEnum(lphEnum);//关闭一次列举
        If Res <> NO_ERROR Then break;//执行失败
    End;
    Result := True;
    FreeMem(Buf);
    NetworkTypeList.Destroy;
End;
procedure TForm49.ComboBox1DropDown(Sender: TObject);
var ls: TStringList;
begin
    ls:= TStringList.Create();
    GetServerList(ls);
    combobox1.Items:=ls;
end;Function GetUsers( GroupName:string; var List:TStringList ) : Boolean;
Var
    NetResource : TNetResource;
    Buf : Pointer;
    Count,BufSize,Res : DWord;
    Ind : Integer;
    lphEnum : THandle;
    Temp:TNetResourceArray;
Begin
    Result := False;
    List.Clear;
    FillChar(NetResource, SizeOf(NetResource), 0);//初始化网络层次信息
    NetResource.lpRemoteName := @GroupName[1];//指定工作组名称
    NetResource.dwDisplayType := RESOURCEDISPLAYTYPE_SERVER;//类型为服务器(工作组)
    NetResource.dwUsage := RESOURCEUSAGE_CONTAINER;
    NetResource.dwScope := RESOURCETYPE_DISK;//列举文件资源信息
    //获取指定工作组的网络资源句柄
    Res := WNetOpenEnum( RESOURCE_GLOBALNET, RESOURCETYPE_DISK,
    RESOURCEUSAGE_CONTAINER, @NetResource,lphEnum);
    If Res <> NO_ERROR Then Exit; //执行失败
    While True Do//列举指定工作组的网络资源
    Begin
        Count := $FFFFFFFF;//不限资源数目
        BufSize := 8192;//缓冲区大小设置为8K
        GetMem(Buf, BufSize);//申请内存,用于获取工作组信息
        //获取计算机名称
        Res := WNetEnumResource(lphEnum, Count, Pointer(Buf),BufSize);
        If Res = ERROR_NO_MORE_ITEMS Then break;//资源列举完毕
        If (Res <> NO_ERROR) then Exit;//执行失败
        Temp := TNetResourceArray(Buf);
        For Ind := 0 to Count - 1 do//列举工作组的计算机名称
        Begin
        //获取工作组的计算机名称,+2表示删除"\\",如\\wangfajun=>wangfajun
            List.Add(Temp^.lpRemoteName + 2);
            Inc(Temp);
        End;
    End;
    Res:= WNetCloseEnum(lphEnum);//关闭一次列举
    If Res <> NO_ERROR Then exit;//执行失败
    Result := True;
    FreeMem(Buf);
End;
procedure TForm49.ComboBox2DropDown(Sender: TObject);
var ls:tstringlist;
begin
 //   if listbox1.ItemIndex>0 then
   // begin
        ls:=tstringlist.Create;
        GetUsers(combobox1.Items.Strings[0],ls);
        combobox2.Items:=ls;
    //end;
end;procedure TForm49.BitBtn1Click(Sender: TObject);//将选出的数据库服务器地址存入文件
var
  MyIniFile: TIniFile;
  filename:string;
  begin
  filename:=ExtractFilePath(paramstr(0))+'server.ini';
  MyIniFile := TIniFile.Create(filename);
  if combobox2.text<>'' then
    MyIniFile.WriteString('host', 'Data Source', combobox2.text);
    MyIniFile.Free;
end;procedure TForm49.FormClose(Sender: TObject; var Action: TCloseAction);
begin
if combobox2.text='' then
   begin
   if application.MessageBox('不选择服务器无法使用本软件,确定要退出?','询问',mb_yesno)=6 then
      begin
      close;
      form1.close;
      end
   else
      abort();
   end;
end;在ADO连接时,将adoconnection中的用户名和密码使用变量来代替,程序中再调用ini文件中的用户名和密码。