function ConnectDb(
out dbConnect : TDatabase
) : integer;
var
strTemp : PChar;
strParams, strIniPath : string;
tstrParams : TStrings;
begin
tstrParams := TStringList.Create; Getmem(strTemp, 128);
strIniPath := GetCurrentDir + '\oa.ini'; GetPrivateProfileString(
'Database', 'DRIVER NAME', 'MSSQL',
strTemp, 128, PChar(strIniPath));
strParams := 'DRIVER NAME=' + strTemp;
tstrParams.Append(strParams);
GetPrivateProfileString(
'Database', 'DATABASE NAME', 'oadb',
strTemp, 128, PChar(strIniPath));
strParams := 'DATABASE NAME=' + strTemp;
tstrParams.Append(strParams); GetPrivateProfileString(
'Database', 'SERVER NAME', '127.0.0.1',
strTemp, 128, PChar(strIniPath));
strParams := 'SERVER NAME=' + strTemp;
tstrParams.Append(strParams); //GetPrivateProfileString(
// 'Database', 'USER NAME', 'oadbo',
// strTemp, 128, PChar(strIniPath));
//strParams := 'USER NAME=' + strTemp;
strParams := 'USER NAME=oadbo';
tstrParams.Append(strParams);
GetPrivateProfileString(
'Database', 'BLOBS TO CACHE', '64',
strTemp, 128, PChar(strIniPath));
strParams := 'BLOBS TO CACHE=' + strTemp;
tstrParams.Append(strParams); GetPrivateProfileString(
'Database', 'BLOB SIZE', '32',
strTemp, 128, PChar(strIniPath));
strParams := 'BLOB SIZE=' + strTemp;
tstrParams.Append(strParams); //GetPrivateProfileString(
// 'Database', 'PASSWORD', 'oadbo',
// strTemp, 128, PChar(strIniPath));
//strParams := 'PASSWORD=' + strTemp;
strParams := 'PASSWORD=oadbo';
tstrParams.Append(strParams); freemem(strTemp); dbConnect.Close;
dbConnect.Params := tstrParams;
dbConnect.LoginPrompt := false;
dbConnect.Open; Result := 0;
end;
out dbConnect : TDatabase
) : integer;
var
strTemp : PChar;
strParams, strIniPath : string;
tstrParams : TStrings;
begin
tstrParams := TStringList.Create; Getmem(strTemp, 128);
strIniPath := GetCurrentDir + '\oa.ini'; GetPrivateProfileString(
'Database', 'DRIVER NAME', 'MSSQL',
strTemp, 128, PChar(strIniPath));
strParams := 'DRIVER NAME=' + strTemp;
tstrParams.Append(strParams);
GetPrivateProfileString(
'Database', 'DATABASE NAME', 'oadb',
strTemp, 128, PChar(strIniPath));
strParams := 'DATABASE NAME=' + strTemp;
tstrParams.Append(strParams); GetPrivateProfileString(
'Database', 'SERVER NAME', '127.0.0.1',
strTemp, 128, PChar(strIniPath));
strParams := 'SERVER NAME=' + strTemp;
tstrParams.Append(strParams); //GetPrivateProfileString(
// 'Database', 'USER NAME', 'oadbo',
// strTemp, 128, PChar(strIniPath));
//strParams := 'USER NAME=' + strTemp;
strParams := 'USER NAME=oadbo';
tstrParams.Append(strParams);
GetPrivateProfileString(
'Database', 'BLOBS TO CACHE', '64',
strTemp, 128, PChar(strIniPath));
strParams := 'BLOBS TO CACHE=' + strTemp;
tstrParams.Append(strParams); GetPrivateProfileString(
'Database', 'BLOB SIZE', '32',
strTemp, 128, PChar(strIniPath));
strParams := 'BLOB SIZE=' + strTemp;
tstrParams.Append(strParams); //GetPrivateProfileString(
// 'Database', 'PASSWORD', 'oadbo',
// strTemp, 128, PChar(strIniPath));
//strParams := 'PASSWORD=' + strTemp;
strParams := 'PASSWORD=oadbo';
tstrParams.Append(strParams); freemem(strTemp); dbConnect.Close;
dbConnect.Params := tstrParams;
dbConnect.LoginPrompt := false;
dbConnect.Open; Result := 0;
end;
解决方案 »
- 求教:winsock recv 收不到数据
- 怎样实现当按下了 DBNavigator 中的insert 按钮后,insert按钮的enabled为false,要按了post按钮才能再次激活insert按钮
- 请问有没有可以多选的类似listbox的控件?
- 求 用DirectDraw抓取屏幕图像的Delphi源代码
- 恭喜!GordonLiWei的blog开张了!!!
- 在未装Delphi6.0与Sql Server2000的机器上运行Delphi编写的exe程序:
- 急急急,高手请进!!!系统开发完了,打包时怎么定制BDE,我只要FOXBASE的数据库引擎!!
- 求求你们了?
- 调用外部exe后,有没有办法自动输入该exe的密码?
- 各位大牛谁有Delphi写的Webserver的例子?不要Webservice的例子
- 如何得到计算机中所有浏览器?
- 当改变DBLookupComboBox的值时,对应的table是否会相应地移动记录指针?
如readsection,readsectionvalue,readstring...等,
MyIniFile: TIniFile;
begin
MyIniFile := TIniFile.Create('myapp.ini');
Memo1.Clear;
MyIniFile.ReadSectionValues('Transfer', Memo1.Lines);
if Memo1.Lines.Values['Title1'] <> 'Picture Painter' then
MyIniFile.WriteString('Transfer', 'Title1', 'Picture Painter');
MyIniFile.Free;
end;procedure TForm1.Button2Click(Sender: TObject);var
MyIniFile: TIniFile;
begin MyIniFile := TIniFile.Create('myapp.ini'); { if the entry wasn抰 there before, delete it now }
if Memo1.Lines.Values['Title1'] = '' then
MyIniFile.DeleteKey('Transfer', 'Title1')
{ otherwise, restore the old value }
else
MyIniFile.WriteString('Transfer', 'Title1', Memo1.Lines.Values['Title1']);
MyIniFile.Free;
end;
USE INIFILES;
读文件
VAR
MYINIFILE:TINIFILE;
FILENAME:STRING;
MODE:INTEGER / STRING;
BEGIN
FILENAME:=EXTRACTFILEPATH(PARAMSTR(0))+‘用电营销MIS. INI’;
MYINIFILE:=TINIFILE. CREATE(FILENAME);
MODE:=MYINIFILE. READINTEGER / READSTRING(‘程序参数’,‘封面参数’,1);
MYINIFILE. DESTROY;
END;
写文件
MODE:=MYINIFILE. READINTEGER(‘程序参数’,‘封面参数’,6);
MYINIFILE. DESTROY;
IF C_FMXSMS. TEXT=‘直接显示’ THEN
MYINIFILE. WRITEINTEGER(‘程序参数’,‘封面参数’,-1);
END;
;注释
[小节名]
关键字=值
...---- 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;