IT貓撲網(wǎng):您身邊最放心的安全下載站! 最新更新|軟件分類|軟件專題|手機(jī)版|論壇轉(zhuǎn)貼|軟件發(fā)布

您當(dāng)前所在位置: 首頁數(shù)據(jù)庫MSSQL → 如何保存數(shù)據(jù)庫連接參數(shù)代碼及步驟詳解

如何保存數(shù)據(jù)庫連接參數(shù)代碼及步驟詳解

時間:2015-06-28 00:00:00 來源:IT貓撲網(wǎng) 作者:網(wǎng)管聯(lián)盟 我要評論(0)

在設(shè)計數(shù)據(jù)庫應(yīng)用程序的時候,經(jīng)常需要將一些信息從程序中獨立出來,以保證程序的可移植性。其中最重要的信息就是數(shù)據(jù)庫的連接參數(shù)。

Delphi中,獲得正確的數(shù)據(jù)庫連接參數(shù)的方法十分簡單,你只需要建立一個數(shù)據(jù)模塊,在其中添加一個ADO Connection,雙擊之,然后在彈出的窗口中選"Use Connection String",單擊"Build"按鈕,在"數(shù)據(jù)鏈接屬性"窗口中選擇適當(dāng)?shù)尿?qū)動引擎,并設(shè)定相應(yīng)的連接參數(shù)就可以了。點擊"確認(rèn)"后,系統(tǒng)將自動生成連接串,顯示在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
?
連接串中各項參數(shù)由分號(;)分隔,具體含義如下:

Provider —— 驅(qū)動類型;

Data Source —— 服務(wù)器名稱;

Initial Catalog —— 數(shù)據(jù)庫名稱;

User ID —— 用戶名;

Password —— 口令;

Persist Security Info —— 是否使用持續(xù)安全驗證。

現(xiàn)在我們所要做的第一件工作是將各項參數(shù)寫入一個INI文件中。

Windows INI文件,可解釋為Windows初始化文件。它是一種專門用來保存應(yīng)用程序初始化信息和運行環(huán)境信息的文本文件。例如Windows 3.1中兩個著名的INI文件win.ini和system.ini就在Windows啟動時定義了Windows環(huán)境中鼠標(biāo)響應(yīng)速度、使用的外殼(shell)程序等設(shè)置,Windows系統(tǒng)附帶的許多應(yīng)用程序也都有自己的INI文件。Windows軟件初始化參數(shù)的獲取與保存是通過讀取擴(kuò)展名為INI的文本文件實現(xiàn)的,即程序運行前先從制定的INI文件中搜索到所需的參數(shù),并反映到程序的運行環(huán)境中,當(dāng)程序退出時又將當(dāng)前的環(huán)境參數(shù)保存到制定的INI文件中。

INI文件是文本文件,由若干section組成,在每個帶括號的標(biāo)題下面,是若干個Keyword和一個等號,每個Keyword會控制應(yīng)用程序某個功能的工作方式,等號右邊的Value制定Keyword的操作方式,其一般形式如下:

以下為引用的內(nèi)容:

[section1]
keyword1=value1
keyword2=value2
[section2]
keyword1=value1
keyword2=value2

其中SectionName和KeywordName分別是段名和關(guān)鍵字明,Value為關(guān)鍵字對應(yīng)的設(shè)定值,如果等號右邊無任何內(nèi)容(value為空),表示W(wǎng)indows應(yīng)用程序已為該Keyword指定了缺省值,如果在整個文件中找不到某個Keyword,同樣表示為它們指定了缺省值,各Section所出現(xiàn)的順序是無關(guān)緊要的,在每一個Section里,各個Keyword的順序同樣也無關(guān)緊要,Keyword的值的類型多為String或Integer,應(yīng)分兩種情況讀寫。

INI文件的書寫有嚴(yán)格的要求:

1、Section的名稱必須加以"["和"]",且"["必須在屏幕的第一列。

2、Keyword名稱也必須從屏幕的第一列開始書寫,且后面必須緊跟"="

3、可以對文件加以注釋,每行注釋須以";"開頭。

依照上述規(guī)則,我們編寫下面的INI文件存儲數(shù)據(jù)庫的連接信息:

以下為引用的內(nèi)容:

[dbParam]
Data Source=GTSERVER
Initial Catalog=SuperWorkFlow
User ID=map
Password=map

下面要做的工作就是編寫代碼,在程序執(zhí)行的時候從INI文件中讀取數(shù)據(jù)庫連接參數(shù),為此,我編寫了下面的代碼:

以下為引用的內(nèi)容:

//RWini.pas
{
模塊名稱:配置文件讀寫
編寫人:blue
編寫日期:2003-4-26
模塊功能:從系統(tǒng)配置文件中讀取系統(tǒng)運行所需的各項參數(shù)
 將系統(tǒng)運行所需的各項參數(shù)寫入系統(tǒng)配置文件
 生成數(shù)據(jù)庫連接字符串
}
unit RWini;
interface
uses INIFiles;
const strINIname = 'db.ini';//INI文件的文件名,大家根據(jù)具體情況修改
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
//從配置文件中讀取數(shù)據(jù)庫連接參數(shù)
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
//將數(shù)據(jù)庫連接參數(shù)寫入配置文件
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
//生成數(shù)據(jù)庫連接串
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.

?
在程序數(shù)據(jù)模塊的Create事件中添加下面的代碼:

以下為引用的內(nèi)容:

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;

?
這樣,在程序執(zhí)行過程中,將自動從INI文件中讀取數(shù)據(jù)庫連接參數(shù),連接數(shù)據(jù)庫,如果連接出現(xiàn)錯誤,將顯示參數(shù)配置窗口,讓用戶配置數(shù)據(jù)庫連接參數(shù)。配置窗口的代碼如下:

<b id="qwowc"><dfn id="qwowc"></dfn></b>
<option id="qwowc"></option>
    • <samp id="qwowc"></samp>

      以下為引用的內(nèi)容:

      //上面的代碼省略
      uses RWini;

      {$R *.dfm}

      關(guān)鍵詞標(biāo)簽:數(shù)據(jù)庫,參數(shù)代碼

      相關(guān)閱讀

      文章評論
      發(fā)表評論

      熱門文章 淺談JSP JDBC來連接SQL Server 2005的方法 淺談JSP JDBC來連接SQL Server 2005的方法 SqlServer2005對現(xiàn)有數(shù)據(jù)進(jìn)行分區(qū)具體步驟 SqlServer2005對現(xiàn)有數(shù)據(jù)進(jìn)行分區(qū)具體步驟 sql server系統(tǒng)表損壞的解決方法 sql server系統(tǒng)表損壞的解決方法 MS-SQL2005服務(wù)器登錄名、角色、數(shù)據(jù)庫用戶、角色、架構(gòu)的關(guān)系 MS-SQL2005服務(wù)器登錄名、角色、數(shù)據(jù)庫用戶、角色、架構(gòu)的關(guān)系

      相關(guān)下載

        人氣排行 配置和注冊O(shè)DBC數(shù)據(jù)源-odbc數(shù)據(jù)源配置教程 如何遠(yuǎn)程備份(還原)SQL2000數(shù)據(jù)庫 SQL2000數(shù)據(jù)庫遠(yuǎn)程導(dǎo)入(導(dǎo)出)數(shù)據(jù) SQL2000和SQL2005數(shù)據(jù)庫服務(wù)端口查看或修改 修改Sql Server唯一約束教程 SQL Server 2005降級到2000的正確操作步驟 sql server系統(tǒng)表損壞的解決方法 淺談JSP JDBC來連接SQL Server 2005的方法