成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

如何保存數據庫連接參數代碼及步驟詳解

數據庫
在設計數據庫應用程序的時候,經常需要將一些信息從程序中獨立出來,以保證程序的可移植性。其中最重要的信息就是數據庫的連接參數。本文中將為大家介紹如何保存數據庫連接參數代碼及步驟詳解。

以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);
niParam := 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;
本文關于如何保存數據庫連接參數代碼及步驟詳解的問題給大家做了詳細的總結,希望對大家能夠有所幫助。

【編輯推薦】

  1. 學習基于SQL數據庫的算法
  2. 詳解SQL Server數據庫的文件恢復技術
  3. SQL Server數據庫連接中常見的錯誤分析

 

責任編輯:迎迎 來源: 賽迪網
相關推薦

2011-07-05 09:54:04

2011-08-01 23:34:34

ASP.NETOracle

2010-06-07 15:24:34

Java連接MYSQL

2009-07-20 15:56:08

JDBC連接數據庫步驟

2010-08-26 11:48:30

DB2外連接交叉連接

2012-02-03 10:32:46

Java

2010-05-28 10:34:39

連接MySQL數據庫

2010-05-26 15:43:37

連接MySQL數據庫

2009-06-16 11:11:25

JBoss目錄數據庫連接

2010-10-26 15:54:02

連接oracle數據庫

2009-06-15 13:46:00

netbeans設置數據庫連接池

2010-02-24 09:47:25

Oracle手動創建數

2009-08-25 14:05:06

C#連接數據庫代碼

2011-07-05 10:03:00

Qt MYSQL 數據庫

2011-07-26 18:11:56

iPhone Sqlite 數據庫

2009-12-31 11:10:01

2010-02-05 09:23:38

C++連接SQL數據庫

2025-03-05 08:30:00

2009-08-25 15:50:13

C#連接遠程數據庫

2011-05-16 14:14:15

數據庫下載
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美极品在线观看 | 欧美日高清 | 欧美一级特黄aaa大片在线观看 | 激情视频一区 | 欧美激情一区二区 | 97伦理| 亚洲一区电影 | 久婷婷| 国产精品天堂 | 色婷婷一区二区三区四区 | 成人精品在线观看 | 夜夜爽99久久国产综合精品女不卡 | 91在线精品秘密一区二区 | 国精品一区二区 | 亚洲人成人一区二区在线观看 | 久操福利 | 日本啊v在线| 麻豆久久久久久 | 亚洲综合色网 | 精品欧美一区二区在线观看欧美熟 | 日韩欧美在线一区 | 国产视频中文字幕 | 亚洲国产成人精品女人久久久 | 国产一区二区在线免费视频 | 羞羞的视频在线 | 91av久久久 | 午夜精品一区二区三区在线视频 | a视频在线 | 成人av免费在线观看 | 中文字幕专区 | 色一级| 国产高清一区二区三区 | 日韩视频中文字幕 | 日韩免费高清视频 | 一级片网址| 精品综合在线 | 成人免费在线 | 欧美一区二区三区在线观看 | 中文字幕精品一区 | 水蜜桃久久夜色精品一区 | 欧美成年网站 |