我做了一个系统,用的是delphi7+SQl Server2000。此系统在本机上,通过ADOconnection1控件,直接设置它的属性,很快就和后台数据库连接成功!就可以是此系统运行的非常流畅。但是我把此系统的可执行文件xxx.exe,拷贝到公司局域网内的其他机子A(这个机子A没有安装delphi)上,把本机做为后台数据库服务器。那么我在拷贝xxx.exe可执行文件的时候,怎么设置ADOconnecttion1的属性呢?怎么设置A机呢,使其可以与本机相连,把本机做为数据库服务器呢,以便调用本机数据?

解决方案 »

  1.   

    可以用INI文件保存数据库服务器名字,然后读取
      

  2.   

    ini的使用网上很多
    Delphi中的INI文件编程
    整理编辑:China ASP
     
    ---- INI文件在系统配置及应用程序参数保存与设置方面,具有很重要的作用,所以可视化的编程一族,如VB、VC、VFP、Delphi等都提供了读写INI文件的方法,其中Delphi中操作INI文件,最为简洁,这是因为Delphi3提供了一个TInifile类,使我们可以非常灵活的处理INI文件。
    一、有必要了解INI文件的结构:
    ;注释
    [小节名]
    关键字=值
    ...
    ---- INI文件允许有多个小节,每个小节又允许有多个关键字, “=”后面是该关键字的值。
    ---- 值的类型有三种:字符串、整型数值和布尔值。其中字符串存贮在INI文件中时没有引号,布尔真值用1表示,布尔假值用0表示。
    ---- 注释以分号“;”开头。
    二、定义
    ---- 1、在Interface的Uses节增加IniFiles;
    ---- 2、在Var变量定义部分增加一行:
    myinifile:Tinifile;
    ---- 然后,就可以对变量myinifile进行创建、打开、读取、写入等操作了。
    三、打开INI文件
    myinifile:=Tinifile.create('program.ini');
    --- 上面这一行语句将会为变量myinifile与具体的文件 program.ini建立联系,然后,就可以通过变量myinifile,来读写program.ini文件中的关键字的值了。
    ---- 值得注意的是,如果括号中的文件名没有指明路径的话,那么这个Program.ini文件会存储在Windows目录中,把Program.ini文件存储在应用程序当前目录中的方法是:为其指定完整的路径及文件名。下面的两条语句可以完成这个功能:
    Filename:=ExtractFilePath(Paramstr(0))+'program.ini';
    myinifile:=Tinifile.Create(filename);
    四、读取关键字的值
    --- 针对INI文件支持的字符串、整型数值、布尔值三种数据类型,TINIfiles类提供了三种不同的对象方法来读取INI文件中关键字的值。
    --- 假设已定义变量vs、vi、vb分别为string、 integer、boolean类型。
    vs:=myinifile.Readstring('小节名','关键字',缺省值);
    vi:=myinifile.Readinteger('小节名','关键字',缺省值);
    vb:=myinifile.Readbool('小节名','关键字',缺省值);
    --- 其中缺省值为该INI文件不存在该关键字时返回的缺省值。
    五、写入INI文件
    ---- 同样的,TInifile类也提供了三种不同的对象方法,向INI文件写入字符串、整型数及布尔类型的关键字。
    myinifile.writestring('小节名','关键字',变量或字符串值);
    myinifile.writeinteger('小节名','关键字',变量或整型数值);
    myinifile.writebool('小节名','关键字',变量或True或False);
    ---- 当这个INI文件不存在时,上面的语句还会自动创建该INI文件。
    六、删除关键字
    ---- 除了可用写入方法增加一个关键字,Tinifile类还提供了一个删除关键字的对象方法:
    myinifile.DeleteKey('小节名','关键字');
    七、小节操作
    --- 增加一个小节可用写入的方法来完成,删除一个小节可用下面的对象方法:
    myinifile.EraseSection('小节名');
    --- 另外Tinifile类还提供了三种对象方法来对小节进行操作:
    --- myinifile.readsection('小节名',TStrings变量);可将指定小节中的所有关键字名读取至一个字符串列表变量中;
    --- myinifile.readsections(TStrings变量);可将INI文件中所有小节名读取至一个字符串列表变量中去。
    ---- myinifile.readsectionvalues('小节名',TStrings变量);可将INI文件中指定小节的所有行(包括关键字、=、值)读取至一个字符串列表变量中去。
    八、释放
    在适当的位置用下面的语句释放myinifile:
    myinifile.distory;
      

  3.   

    cnnectionstring不能写死在程序里,你必须设置可以调整的接口
      

  4.   

    在数据连接控件TAdoconnection放置的窗体创建时从外部文件中读取connectionstring属性值
      

  5.   

    从外部的INI文件读取connectionstring参数
    procedure TLocalDM.DataModuleCreate(Sender: TObject);
    var
      LogoCfg: TIniFile;
      UserName, ServerName, Pass: string;
      strsql:string;
    begin
       LogoCfg:=TIniFile.Create(ExtractFilePath(Application.ExeName)+'\LogoCfg.ini');
      try
        UserName := LogoCfg.ReadString('Config','Name','');
        ServerName := LogoCfg.ReadString('Config','ServerName','');
        Pass  := LogoCfg.ReadString('Config','Password','');
      finally
        LogoCfg.Free;
      end; ADOConnection1.ConnectionString := 'Provider=SQLOLEDB.1;Password=' + Pass +
                                        ';Persist Security Info=True;'+
                                        'User ID=sa' +
                                        ';Initial Catalog=kkk'+
                                        ';Data Source='+ServerName;
    end;