有效使用ADO操作相關(guān)實(shí)現(xiàn)
其中路徑名可以根據(jù)自己系統(tǒng)安裝的ADO支持文件的路徑來(lái)自行設(shè)定。當(dāng)編譯器遇到#import語(yǔ)句時(shí),它會(huì)為引用組件類型庫(kù)中的接口生成包裝類,#import語(yǔ)句實(shí)際上相當(dāng)于執(zhí)行了API涵數(shù)LoadTypeLib()。ADO操作語(yǔ)句會(huì)在工程可執(zhí)行程序輸出目錄中產(chǎn)生兩個(gè)文件。
分別為*.tlh(類型庫(kù)頭文件)及*.tli(類型庫(kù)實(shí)現(xiàn)文件),它們分別為每一個(gè)接口產(chǎn)生智能指針,并為各種接口方法、枚舉類型,CLSID等進(jìn)行聲明,創(chuàng)建一系列包裝方法。語(yǔ)句no_namespace說(shuō)明ADO對(duì)象不使用命名空間,rename ("EOF", "adoEOF")說(shuō)明將ADO中結(jié)束標(biāo)志EOF改為adoEOF,ADO操作以避免和其它庫(kù)中命名相沖突。
其次,在程序初始過(guò)程中需要初始化組件。
一般可以用CoInitialize(NULL);來(lái)實(shí)現(xiàn),這種方法在結(jié)束時(shí)要關(guān)閉初始化的COM,可以用下面語(yǔ)句CoUnInitialize();來(lái)實(shí)現(xiàn)。在MFC中還可以采用另一種方法來(lái)實(shí)現(xiàn)初始化COM,這種方法只需要一條語(yǔ)句便可以自動(dòng)為我們實(shí)現(xiàn)初始化COM和結(jié)束時(shí)關(guān)閉ADO操作的操作,語(yǔ)句如下所示: AfxOleInit();
接著,就可以直接使用ADO操作了。我們經(jīng)常使用的只是前面用#import語(yǔ)句引用類型庫(kù)時(shí),生成的包裝類.tlh中聲明的智能指針中的三個(gè),它們分別是_ConnectionPtr、_RecordsetPtr和_CommandPtr。下面分別對(duì)它們的使用方法進(jìn)行介紹:#t#
ConnectionPtr智能指針,通常用于打開(kāi)、關(guān)閉一個(gè)庫(kù)連接或用它的Execute方法來(lái)執(zhí)行一個(gè)不返回結(jié)果的命令語(yǔ)句(用法和_CommandPtr中的Execute方法類似)。
——打開(kāi)一個(gè)庫(kù)連接。先創(chuàng)建一個(gè)實(shí)例指針,再用Open打開(kāi)一個(gè)庫(kù)連接,它將返回一個(gè)IUnknown的自動(dòng)化接口指針。代碼如下所示:
在工具箱中,新的控件——DataGridView, DataConnector和DataNavigator。利用這些控件,你能在數(shù)據(jù)綁定控件中提供數(shù)據(jù)導(dǎo)航(分頁(yè))功能。 DbProvidersFactories類這個(gè)類能提供當(dāng)前機(jī)器里的現(xiàn)有數(shù)據(jù)提供者(providers)列表。在寫數(shù)據(jù)庫(kù)依賴程序時(shí),ADO操作你能利用這個(gè)類及其成員為你的數(shù)據(jù)庫(kù)查找最適合的數(shù)據(jù)提供者。
自定義數(shù)據(jù)提供者(Provider) 通過(guò)提供工廠類,現(xiàn)在ADO操作可以擴(kuò)展支持自定義數(shù)據(jù)提供者功能。你無(wú)需編寫一個(gè)數(shù)據(jù)提供者支持代碼。你可以用數(shù)據(jù)提供者基類以及連接字符串幫助你完成這些功能。


















