开发MIS,数据库是SQL SERVER。设计阶段把AdoConnection的ConnectString设置好, 数据库服务器改了名字就无法连上了。考虑过用udl文件,但如果让客户修改UDL文件似乎不大合适(有些繁琐)。关于这个问题,大家是怎么做的呢?添加一个设置联接属性的窗口?会把这个窗口安排在哪里?提供哪些输入(服务器名?数据库名?)?
解决方案 »
- 判断是否中文用ord(str[i])>=127的话,有什么问题呢?
- delphi webbrowser 页面内转问题(新页面打开)
- 请问Delphi连接Access数据库有没有类似以下VB的语句?
- 连锁店进销存软件开发工具的选择及软件架构
- 请高手指点以下的代码,看问题出在哪里。。先感谢了。。。。。。。
- 如何取得键盘上同时按下的两个或更多个的键?比如space+a+b+c
- 如何在日期型数据中提采年份和月份
- 使用ClientDataset做insert,手机会出现 Exception in safecall method,怎么回事啊
- 有人知道DELPHI的指针吗?
- sos 紧急求助!!!
- delphi 中有整型转成浮点型的函数吗??
- 怎样写类哪? 求教!
定义一个常量 SConnStr := 'XXXXXXXXXX %s XXXXXXXXXX' 不好意思有点忘了connect string如何写了, 不过这不重要,连接字段串你可从你设计其的ADOConnection中的ConnectString中复制,要把数据库的名字用%s来代替,然后把你的ADOConnection的Active设为False, 设计一个让用户可以输入数据库名字的窗体,让用户设置,程序使用的时候就可以把ADOConnection的ConnectString 设为 Format(SConnStr, [数据库名字]),再把ADOConnection的Active设为True就可以了。
ADOConnection1.ConnectionString := 'Provider=SQLOLEDB.1;Persist Security Info=False;User ID=sa;Initial Catalog=master;Data Source=' + iniserver.ReadString('server', 'name', '');
var
Form1: TForm1;
loadini:TIniFile;implementation{$R *.DFM}procedure TForm1.epEfButton2Click(Sender: TObject);
begin
close;
end;procedure TForm1.FormShow(Sender: TObject);
begin
try
loadini:=TIniFile.Create(ExtractFilePath(Application.ExeName)+'configinfo.ini');
edit1.Text:=loadini.ReadString('config','ServerName','');
edit2.Text:=loadini.ReadString('config','dataname','');
Except
ShowMessage('无法读取配置文件!');
Close;
end;
end;procedure TForm1.epEfButton1Click(Sender: TObject);
begin
try
loadini.WriteString('config','ServerName',Edit1.Text);
loadini.WriteString('config','dataname',Edit2.Text);
ShowMessage('更改成功!');
close;
except
ShowMessage('更改失败!');
end;
end;end.
先loadini:=TIniFile.Create(ExtractFilePath(Application.ExeName)+'configinfo.ini');
再ADOConnection1.connected:=True;(若ini文件如 delphiseabird(沙鸥) 所说)?
设置服务器的对话框一般放哪呢?程序一开始第一个对话框就是它?
s: String;
begin
DataConnection.Connected := False;
s := PromptDataSource(Handle, DataConnection.ConnectionString);
if CompareText(s, DataConnection.ConnectionString) <> 0 then
DataConnection.ConnectionString := s;
DataConnection.Connected := True;
end;
在Delphi中,获得正确的数据库连接参数的方法十分简单,你只需要建立一个数据模块,在其中添加一个ADO Connection,双击之,然后在弹出的窗口中选“Use Connection String”,单击“Build”按钮,在“数据链接属性”窗口中选择适当的驱动引擎,并设定相应的连接参数就可以了。点击“确认”后,系统将自动生成连接串,显示在Object Inspector的Connection String中。
以Microsoft SQL Server 为例,连接串就类似于:Provider=SQLOLEDB.1;Password=map;Persist Security Info=True;User ID=map;Initial Catalog=SuperWorkFlow;Data Source=GTSERVER连接串中各项参数由分号(;)分隔,具体含义如下:Provider —— 驱动类型
Data Source —— 服务器名称
Initial Catalog —— 数据库名称
User ID —— 用户名
Password —— 口令
Persist Security Info —— 是否使用持续安全验证现在我们所要做的第一件工作是将各项参数写入一个INI文件中。
Windows INI文件,可解释为Windows初始化文件。它是一种专门用来保存应用程序初始化信息和运行环境信息的文本文件。例如Windows 3.1中两个著名的INI文件win.ini和system.ini就在Windows启动时定义了Windows环境中鼠标响应速度、使用的外壳(shell)程序等设置,Windows系统附带的许多应用程序也都有自己的INI文件。Windows软件初始化参数的获取与保存是通过读取扩展名为INI的文本文件实现的,即程序运行前先从制定的INI文件中搜索到所需的参数,并反映到程序的运行环境中,当程序退出时又将当前的环境参数保存到制定的INI文件中。
INI文件是文本文件,由若干section组成,在每个带括号的标题下面,是若干个Keyword和一个等号,每个Keyword会控制应用程序某个功能的工作方式,等号右边的Value制定Keyword的操作方式,其一般形式如下:[section1]
keyword1=value1
keyword2=value2
[section2]
keyword1=value1
keyword2=value2其中SectionName和KeywordName分别是段名和关键字明,Value为关键字对应的设定值,如果等号右边无任何内容(value为空),表示Windows应用程序已为该Keyword指定了缺省值,如果在整个文件中找不到某个Keyword,同样表示为它们指定了缺省值,各Section所出现的顺序是无关紧要的,在每一个Section里,各个Keyword的顺序同样也无关紧要,Keyword的值的类型多为String或Integer,应分两种情况读写。
INI文件的书写有严格的要求:
1、Section的名称必须加以“[”和“]”,且“[”必须在屏幕的第一列。
2、Keyword名称也必须从屏幕的第一列开始书写,且后面必须紧跟“=”
3、可以对文件加以注释,每行注释须以“;”开头。
依照上述规则,我们编写下面的INI文件存储数据库的连接信息:[dbParam]
Data Source=GTSERVER
Initial Catalog=SuperWorkFlow
User ID=map
Password=map下面要做的工作就是编写代码,在程序执行的时候从INI文件中读取数据库连接参数,为此,我编写了下面的代码://RWini.pas
{
模块名称:配置文件读写
编写人:blue
编写日期:2003-4-26
模块功能:从系统配置文件中读取系统运行所需的各项参数
将系统运行所需的各项参数写入系统配置文件
生成数据库连接字符串
}
unit RWini;
interface
uses INIFiles;
const strINIname = 'db.ini';//INI文件的文件名,大家根据具体情况修改
var
iniParam : TINIFile;
strLocal : String;
procedure readParam(out server:String;out database:string;out user:string;out password:string);
procedure writeParam(server:string;database:string;user:string;password:string);
function getConnStr:string;
implementation procedure readParam(out server:String;out database:string;out user:string;out password:string);
begin
//从配置文件中读取数据库连接参数
server := iniParam.ReadString('dbParam','Data Source','');
database := iniParam.ReadString('dbParam','Initial Catalog','');
user := iniParam.ReadString('dbParam','User ID','');
password := iniParam.ReadString('dbParam','Password','');
end; procedure writeParam(server:string;database:string;user:string;password:string);
begin
//将数据库连接参数写入配置文件
iniParam.WriteString('dbParam','Data Source',server);
iniParam.WriteString('dbParam','Initial Catalog',database);
iniParam.WriteString('dbParam','User ID',user);
iniParam.WriteString('dbParam','Password',password);
end; function getConnStr:String;
var
server,database,user,password : String;
begin
//生成数据库连接串
readParam(server,database,user,password);
result := 'Provider=SQLOLEDB.1;Password=' + password + ';Persist Security Info=True;User ID=' + user + ';Initial Catalog=' + database + ';Data Source=' + server;
end;initialization
getDir(0,strLocal);
iniParam := TINIFile.Create(strLocal + '\' + strINIname);finalization
iniParam.Free;
end.在程序数据模块的Create事件中添加下面的代码:procedure TDM.DataModuleCreate(Sender: TObject);
var
confForm : TConf;
begin
conn.ConnectionString := RWini.getConnStr;
try
conn.Open;
except
on Err : EOLEException do
begin
confForm := TConf.Create(self);
confForm.ShowModal;
end;
end;
end;这样,在程序执行过程中,将自动从INI文件中读取数据库连接参数,连接数据库,如果连接出现错误,将显示参数配置窗口,让用户配置数据库连接参数。配置窗口的代码如下://上面的代码省略
uses RWini;{$R *.dfm}procedure TConf.FormShow(Sender: TObject);
var
sServer,sDatabase,sUser,sPassword : String;
begin
readParam(sServer,sDatabase,sUser,sPassword);
self.edtServer.Text := sServer;
self.edtDatabase.Text := sDatabase;
self.edtUser.Text := sUser;
self.edtPassword.Text := sPassword;
self.ActiveControl := self.btnOK;
end;procedure TConf.btnCancelClick(Sender: TObject);
begin
close;
end;procedure TConf.btnOKClick(Sender: TObject);
var
sServer,sDatabase,sUser,sPassword : String;
begin
sServer := self.edtServer.Text;
sDatabase := self.edtDatabase.Text;
sUser := self.edtUser.Text;
sPassword := self.edtPassword.Text;
writeParam(sServer,sDatabase,sUser,sPassword);
close;
end;是不是很简单呢?INI文件不仅可以保存数据库连接参数,也同样可以保存其他信息,具体的方法大同小异,我就不再详述了。
祝大家编程愉快!
模块名称:注册表读写
编写人:blue
编写日期:2003-9-9
模块功能:将数据库连接参数写入注册表
从注册表中读出数据库连接参数
生成数据里连接串
}
unit RWReg;interfaceuses Registry;const strCompanyName = 'Congia Inc';procedure readParam(out server:String;out database:string;out user:string;out password:string);
procedure writeParam(server:string;database:string;user:string;password:string);
function getConnStr:string;var
reg : TRegistry;implementationprocedure readParam(out server:String;out database:string;out user:string;out password:string);
begin
//从注册表中读取数据库连接参数
server := reg.ReadString('Data Source');
database := reg.ReadString('Initial Catalog');
user := reg.ReadString('User ID');
password := reg.ReadString('Password');
end;procedure writeParam(server:string;database:string;user:string;password:string);
begin
//将数据库连接参数写入注册表
reg.WriteString('Data Source',server);
reg.WriteString('Initial Catalog',database);
reg.WriteString('User ID',user);
reg.WriteString('Password',password);
end;function getConnStr:string;
var
server,database,user,password : String;
begin
//生成连接字符串
readParam(server,database,user,password);
result := 'Provider=SQLOLEDB.1;Password=' + password + ';Persist Security Info=True;User ID=' + user + ';Initial Catalog=' + database + ';Data Source=' + server;
end;initialization
reg := TRegistry.Create;
reg.OpenKey('\' + strCompanyName + '\Conn',True);
finalization
reg.CloseKey;
reg.Free;
end.
我要好好学学!