ODBC開放數(shù)據(jù)庫互連(Open Database Connectivity)是微軟公司開放服務結構(WOSA,Windows Open Services Architecture)中有關數(shù)據(jù)庫的一個組成部分,它建立了一組規(guī)范,并提供了一組對數(shù)據(jù)庫訪問的標準API(應用程序編程接口)。這些API利用SQL來完成其大部分任務。ODBC本身也提供了對SQL語言的支持,用戶可以直接將SQL語句送給ODBC。
ADO (ActiveX Data Objects) 是微軟公司的一個用于存取數(shù)據(jù)源的COM組件。它提供了編程語言和統(tǒng)一數(shù)據(jù)訪問方式OLE DB的一個中間層。允許開發(fā)人員編寫訪問數(shù)據(jù)的代碼而不用關心數(shù)據(jù)庫是如何實現(xiàn)的,而只用關心到數(shù)據(jù)庫的連接。訪問數(shù)據(jù)庫的時候,關于SQL的知識不是必要的,但是特定數(shù)據(jù)庫支持的SQL命令仍可以通過ADO中的命令對象來執(zhí)行。ADO被設計來繼承微軟早期的數(shù)據(jù)訪問對象層,包括RDO (Remote Data Objects) 和DAO(Data Access Objects)。
使用#import方法對ADO進行操作
在#import中,你需要提供所包含的類型庫的路徑和名稱,它能夠自動產生一個對GUIDs的定義,同時對自動生成對ADO對象的封裝。
還能夠列舉它在類型庫中所能找到的類型,對任何你所引用的類型庫,VC++會在編譯的時候自動生成兩個文件:
一個頭文件(.tlh),它包含了列舉的類型和對類型庫中對象的定義。
一個實現(xiàn)文件(.tli)對類型庫對象模型中的方法產生封裝。
例
#import "c:\Program Files\common files\system\ado\msado15.dll" no_namespace rename("EOF","adoEOF")
/*VC++會自動產生msado15.tlh和msado15.tli兩個文件。no_namespace意味著你不需要在初始化變量的時候引用名字空間。對EOF進行該名,是必要的,因為典型的VC++應用都已經(jīng)定義了EOF作為常數(shù)-1*/
CoInitialize(NULL);
/*CoInitialize是 Windows提供的API函數(shù),用來告訴 Windows以單線程的方式創(chuàng)建com對象。參數(shù)被保留,且必須為NULL。CoInitialize并不裝載COM 庫,它只用來初始化當前線程使用什么樣的套間。使用這個函數(shù)后,線程就和一個套間建立了對應關系,線程在此套間運行。CoInitialize和CoUninitialize必須成對使用。*/
_ConnectionPtr m_pConnection(_uuidof(Connection)); //使用智能指針產生一個連接指針
_RecordsetPtr m_pRecordset(_uuidof(Recordset)); //使用智能指針產生一個記錄集指針
try{
m_pConnection->Open("DSN=Student","","",0); //建立連接,DSN(Data Source Name )是你要連接ODBC數(shù)據(jù)源的名稱
m_pRecordset = m_pConnection->Execute("select * from Student",NULL,adCmdText); //執(zhí)行查詢語句
while(!m_pRecordset->adoEOF)
{
_variant_t TheValue; //_variant_t封裝并管理VARIANT數(shù)據(jù)類型,是COM中使用的數(shù)據(jù)類型,COM是Component Object Model(組件對象模型)
TheValue = m_pRecordset->GetCollect("Sname"); //獲取表中字段為“Sname”的值
m_pRecordset->MoveNext(); //移動到下一條記錄
}
}catch(_com_error e)
{
AfxMessageBox(e.ErrorMessage());
}
m_pRecordset->Close();
m_pConnection->Close();
m_pRecordset = NULL;
m_pConnection = NULL;
CoUninitialize();