- 相關(guān)推薦
vc++中的ADO的應用
摘要介紹了ADO的特點(diǎn)以及在VC++中如何通過(guò)ADO開(kāi)發(fā)數據庫應用程序。ADO是開(kāi)發(fā)訪(fǎng)問(wèn)OLE數據庫應用程序所使用的一種數據庫訪(fǎng)問(wèn)組件,是一種可以訪(fǎng)問(wèn)各種數據類(lèi)型的連接機制。它不僅可以通過(guò)OLEDB、ODBC訪(fǎng)問(wèn)數據庫,還可以使用幾乎任何一種數據源,如SQLServer、Oracle、Access、Excel和文本文件、圖形文件等。ADO基于OLEDB,提供統一的數據訪(fǎng)問(wèn)接口,使用簡(jiǎn)單,容易掌握。
關(guān)鍵詞ADO;數據庫;應用程序的開(kāi)發(fā);VC++
1引言
ADO是Microsoft公司新的數據訪(fǎng)問(wèn)技術(shù),由于它是基于OLEDB接口上實(shí)現的COM對象,其性能和易用性都達到了極佳水平。ADO并不與數據庫直接打交道,而是要通過(guò)ODBC驅動(dòng)程序或OLEDB連接字符串來(lái)操作數據庫。ODBC或OLEDB是應用程序與數據庫進(jìn)行連接通信的接口,其作用是將特定類(lèi)型數據庫中的數據變換為標準而能統一操作的數據源。利用ADO對象并通過(guò)ODBC或OLEDB,可以實(shí)現對任意數據庫的存取和訪(fǎng)問(wèn)。
ADO模型包括7個(gè)對象,主要對象有3個(gè):Connection、Command和Recordset,可以被獨立創(chuàng )建和釋放。此外,還包括其他4個(gè)集合對象:Fields、Errors、Parameters和Properties。一個(gè)典型的ADO應用程序使用Connection對象建立與數據源的連接,然后用一個(gè)Command對象給出對數據庫操作的命令,如插入數據或者查詢(xún)數據等,而Recordset用于對結果集進(jìn)行維護或者瀏覽等操作。其中Command命令所使用的語(yǔ)言與低層所對應的OLEDB數據源有關(guān),不同的數據源可以使用不同的命令語(yǔ)言,對于關(guān)系數據庫,通常使用SQL作為命令語(yǔ)言。
2VC++中使用ADO開(kāi)發(fā)數據庫應用程序一般步驟
在VC++中使用ADO開(kāi)發(fā)數據庫應用程序一般包括以下步驟:
。1)初始化COM庫,引入ADO庫定義文件。
。2)用Connection對象連接數據庫。
。3)利用建立好的連接,通過(guò)Connection、Command對象執行SQL命令,或利用Recordset對象取得結果記錄集進(jìn)行處理、查詢(xún)。
。4)使用完后關(guān)閉連接,釋放對象所占的資源。
3ADO使用實(shí)例
3.1引入ADO動(dòng)態(tài)鏈接庫,初始化COM庫環(huán)境
在使用VisualC++的MFC編程時(shí),MFC并沒(méi)有提供對ADO的封裝類(lèi),能夠支持ADO編程的是ADO的COM動(dòng)態(tài)鏈接庫文件msado*.dll,“*”位置的數字代表ADO庫的版本。引入該文件的方法是在stdafx.h頭文件中,添加如下代碼:
#import”c:programfilescommonfilessystemadomaado15.dll”
no_namespacerename(“EOF”,”adoEOF”)
這些命令聲明在工程中使用ADO,但不使用ADO的名字空間,并為了避免沖突,將EOF改名為adoEOF。
ADO是基于COM技術(shù)的,所以,在應用程序調用ADO前,必須初始化COM庫環(huán)境。ADO使用結束后需要關(guān)閉庫,釋放初始化加載的動(dòng)態(tài)鏈接庫。
::CoInitialize(NULL);//初始化COM庫
::CoUninitialize();//清除COM庫
3.2創(chuàng )建ADO與數據庫的連接
使用Connection對象打開(kāi)連接,在引入的動(dòng)態(tài)鏈接庫生成的定義文件(msado15.tlh)中Open方法的定義如下:
HRESULTOpen(_bstr_tConnectionString,_bstr_tUserID,_bstr_tPassword,longOptions)
由于使用的數據庫軟件的不同,連接串的格式也有所不同,給程序員帶來(lái)很多麻煩。微軟公司提供了一種可視化的方法來(lái)解決這個(gè)問(wèn)題,它提供了通用數據連接文件(UDL)來(lái)建立和測試ADO的連接屬性。
主要代碼如下:
HRESULT_ConnectionPtrm_pConnection;//連接對象智能指針
//初始化數據庫連接
HRESULThr;
try
{
hr=m_pConnection.CreateInstance(_uuidof(Connection));//實(shí)例化連接對象
if(SUCCEEDED(hr))
{
//設置連接串屬性為UDL文件
m_pConnection->ConnectionString=”FileName=name.udl”;
//設置等待連接打開(kāi)的時(shí)間為20s
m_pConnection->ConnectionTimeout=20;
hr=m_pConnection->Open(””,””,””,adConnectUnspecified);
if(FAILED(hr))
{
AfxMessageBox(“Openfail”);
ReturnTRUE;
}
}
else
{
AfxMessageBox(“createinstanceofConnectionfail”);
returnTRUE;
}
}
catch(_com_errore)
{
//給出異常信息
_bstr_tbstrSource(e,Source());
_bstr_tbstrDescription(e.Description());
AfxMessageBox(bstrSource+bstrDescription)
returnTRUE;
}
3.3使用記錄集(Recordset)對象操作數據庫
在A(yíng)DO程序中,記錄集實(shí)際上緩存可從數據庫獲得的記錄,應用程序可以從記錄集中獲得每條記錄的字段。Open方法在msado15.h文件中的定義如下:
HRESULTOpen(const_variant_t&Source,const_variant_t&ActiveConntction,enumCursorTypeEnumCursorType,enumLockTypeEnumLockType,longoptions)
其中,參數Source是記錄源;參數ActiveConntction指定在哪個(gè)連接中打開(kāi)該記錄集;參數CursorType指定打開(kāi)Recordset時(shí)使用的游標;參數LockType指定打開(kāi)記錄集時(shí)應該使用的鎖定類(lèi)型;參數options指定參數Source的種類(lèi)。
主要代碼如下:
HRESULThr;
_variant_tvar;
_RecordsetPtrpRecordset;//定義記錄集指針
hr=pRecordset.CreateInstance(_uuidof(Recordset));//實(shí)例化記錄集指針
CStringstrsql;
strsql=”SELECT*FROMnametable”//定義并初始化SQL語(yǔ)句字符串,nametable為表名
try
{//利用Open函數執行SQL命令,獲得查詢(xún)結果記錄集
hr=pRecordset->Open(_variant_t(strsql),m_pConnection.GetInterfacePtr(),adOpenDynamic,
adLockOptimistic,adCmdText);
if(hr)
{
while(!pRecordset->adoEOF)
{//獲取第1列的值,從0開(kāi)始計數,也可以直接給出列的名字
var=pRecordset->GetCollect((long)0);
var=pRecordset->GetCollect(“Name”);
pRecordset->MoveNext();//移動(dòng)當前記錄到下一條記錄
}
pRecordset->MoveFirst();//移動(dòng)到首條記錄
pRecordset->Delete(adAffectCurent);//刪除當前記錄
pRecordset->AddNew();//添加新記錄
pRecordset->PutCollect(“ID”,_variant_t((long)72));
pRecordset->PutCollect(“Name”,_variant_t(“小王”));
pRecordset->MoveNext();
pRecordset->PutCollect(“Name”,_variant_t(“小周”));//修改Name字段的值
pRecordset->Update//保存到數據庫中
}
else
{
AfxMessageBox(“Openrecordsetfail”);
return;
}
}
catch(_com_error*e)
{
AfxMessageBox(e->ErrorMessage());
return;
}
pRecordset->Close();
pRecordset=NULL;
3.4使用Command對象操作數據庫
Command對象定義了將對數據源執行的指定命令。使用Command對象的流程和記錄集對象類(lèi)似,首先聲明_CommandPtr變量;實(shí)例化變量;設置對象的某些屬性值;調用Execute方法執行命令。所以,這里就不給出代碼了。
4結束語(yǔ)
ADO是應用級的編程接口,它以OLEDB為基礎,對OLEDB進(jìn)行了封裝。它的主要優(yōu)點(diǎn)是易于使用、速度快、內存支出少和使用較少的網(wǎng)絡(luò )流量。ADO技術(shù)是微軟大力支持和發(fā)展的技術(shù),對于致力與VisualC++的程序員來(lái)說(shuō),了解和掌握ADO技術(shù)具有深遠的意義。
參考文獻
[1]原奕等編著(zhù).VisualC++實(shí)踐與提高——數據庫開(kāi)發(fā)與工程應用篇[M].北京:中國鐵道出版社,2006
[2]DavidSceppa著(zhù),石鈞,葛俊譯.ADO編程技術(shù)[M].北京:清華大學(xué)出版社,2001
[3]厄拉森.MFCVisualC++6編程技術(shù)內幕[M].北京:機械工業(yè)出版社,2000
[4]江淑娟,蘇蕊等.利用ADO方法在C/S模式下實(shí)現遠程數據訪(fǎng)問(wèn)[J],山東科技大學(xué)學(xué)報(自然科學(xué)版),2003,22(1):73-75
【vc++中的ADO的應用】相關(guān)文章:
有關(guān)ADO與ADO.NET的區別與介紹03-29
刺繡在服裝中的應用03-22
CAD在設計施工中的應用03-04
色彩在設計中的應用方法12-19
Excel在審計中的應用06-22
CAD在工程制圖課程中的應用03-30
CAD在環(huán)境工程中的應用03-03
油脂在烘焙食品技術(shù)中的應用03-11
漢字在平面設計中的應用03-06