ADO在VC++中的應(yīng)用_第1頁
ADO在VC++中的應(yīng)用_第2頁
ADO在VC++中的應(yīng)用_第3頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、ADO在VC+中的應(yīng)用摘要介紹了AD的特點(diǎn)以及在V+中如何通過AD開發(fā)數(shù)據(jù)庫應(yīng)用程序。AD是開發(fā)訪問LE數(shù)據(jù)庫應(yīng)用程序所使用的一種數(shù)據(jù)庫訪問組件,是一種可以訪問各種數(shù)據(jù)類型的連接機(jī)制。它不僅可以通過LEDB、DB訪問數(shù)據(jù)庫,還可以使用幾乎任何一種數(shù)據(jù)源,如SQLServer、rale、Aess、Exel和文本文件、圖形文件等。AD基于LEDB,提供統(tǒng)一的數(shù)據(jù)訪問接口,使用簡(jiǎn)單,容易掌握。關(guān)鍵詞AD;數(shù)據(jù)庫;應(yīng)用程序的開發(fā);V+1引言AD是irsft公司新的數(shù)據(jù)訪問技術(shù),由于它是基于LEDB接口上實(shí)現(xiàn)的對(duì)象,其性能和易用性都到達(dá)了極佳程度。AD并不與數(shù)據(jù)庫直接打交道,而是要通過DB驅(qū)動(dòng)程序或LE

2、DB連接字符串來操作數(shù)據(jù)庫。DB或LEDB是應(yīng)用程序與數(shù)據(jù)庫進(jìn)展連接通信的接口,其作用是將特定類型數(shù)據(jù)庫中的數(shù)據(jù)變換為標(biāo)準(zhǔn)而能統(tǒng)一操作的數(shù)據(jù)源。利用AD對(duì)象并通過DB或LEDB,可以實(shí)現(xiàn)對(duì)任意數(shù)據(jù)庫的存取和訪問。AD模型包括7個(gè)對(duì)象,主要對(duì)象有3個(gè):nnetin、and和Rerdset,可以被獨(dú)立創(chuàng)立和釋放。此外,還包括其他4個(gè)集合對(duì)象:Fields、Errrs、Paraeters和Prperties。一個(gè)典型的AD應(yīng)用程序使用nnetin對(duì)象建立與數(shù)據(jù)源的連接,然后用一個(gè)and對(duì)象給出對(duì)數(shù)據(jù)庫操作的命令,如插入數(shù)據(jù)或者查詢數(shù)據(jù)等,而Rerdset用于對(duì)結(jié)果集進(jìn)展維護(hù)或者閱讀等操作。其中and

3、命令所使用的語言與低層所對(duì)應(yīng)的LEDB數(shù)據(jù)源有關(guān),不同的數(shù)據(jù)源可以使用不同的命令語言,對(duì)于關(guān)系數(shù)據(jù)庫,通常使用SQL作為命令語言。2V+中使用AD開發(fā)數(shù)據(jù)庫應(yīng)用程序一般步驟在V+中使用AD開發(fā)數(shù)據(jù)庫應(yīng)用程序一般包括以下步驟:1初始化庫,引入AD庫定義文件。2用nnetin對(duì)象連接數(shù)據(jù)庫。3利用建立好的連接,通過nnetin、and對(duì)象執(zhí)行SQL命令,或利用Rerdset對(duì)象獲得結(jié)果記錄集進(jìn)展處理、查詢。4使用完后關(guān)閉連接,釋放對(duì)象所占的資源。3AD使用實(shí)例3.1引入AD動(dòng)態(tài)鏈接庫,初始化庫環(huán)境在使用Visual+的F編程時(shí),F(xiàn)并沒有提供對(duì)AD的封裝類,可以支持AD編程的是AD的動(dòng)態(tài)鏈接庫文件s

4、ad*.dll,“*位置的數(shù)字代表AD庫的版本。引入該文件的方法是在stdafx.h頭文件中,添加如下代碼:#iprt:prgrafilesnfilessysteadaad15.dlln_naespaerenae(“EF,adEF)這些命令聲明在工程中使用AD,但不使用AD的名字空間,并為了防止沖突,將EF改名為adEF。AD是基于技術(shù)的,所以,在應(yīng)用程序調(diào)用AD前,必須初始化庫環(huán)境。AD使用完畢后需要關(guān)閉庫,釋放初始化加載的動(dòng)態(tài)鏈接庫。:Initialize(NULL);/初始化庫:Uninitialize();/去除庫3.2創(chuàng)立AD與數(shù)據(jù)庫的連接使用nnetin對(duì)象翻開連接,在引入的動(dòng)態(tài)鏈

5、接庫生成的定義文件sad15.tlh中pen方法的定義如下:HRESULTpen(_bstr_tnnetinString,_bstr_tUserID,_bstr_tPassrd,lngptins)由于使用的數(shù)據(jù)庫軟件的不同,連接串的格式也有所不同,給程序員帶來很多費(fèi)事。微軟公司提供了一種可視化的方法來解決這個(gè)問題,它提供了通用數(shù)據(jù)連接文件UDL來建立和測(cè)試AD的連接屬性。主要代碼如下:HRESULT_nnetinPtr_pnnetin;/連接對(duì)象智能指針/初始化數(shù)據(jù)庫連接HRESULThr;tryhr=_pnnetin.reatEinstane(_uuidf(nnetin);/實(shí)例化連接對(duì)象i

6、f(SUEEDED(hr)/設(shè)置連接串屬性為UDL文件_pnnetin-nnetinString=FileNae=nae.udl;/設(shè)置等待連接翻開的時(shí)間為20s_pnnetin-nnetinTieut=20;hr=_pnnetin-pen(,adnnetUnspeified);if(FAILED(hr)AfxessageBx(“penfail);ReturnTRUE;elseAfxessageBx(“reateinstanefnnetinfail);returnTRUE;ath(_errre)/給出異常信息_bstr_tbstrSure(e,Sure();_bstr_tbstrDesript

7、in(e.Desriptin();AfxessageBx(bstrSure+bstrDesriptin)returnTRUE;3.3使用記錄集Rerdset對(duì)象操作數(shù)據(jù)庫在AD程序中,記錄集實(shí)際上緩存可從數(shù)據(jù)庫獲得的記錄,應(yīng)用程序可以從記錄集中獲得每條記錄的字段。pen方法在sad15.h文件中的定義如下:HRESULTpennst_variant_tSure,nst_variant_tAtivennttin,enuursrTypeEnuursrType,enuLkTypeEnuLkType,lngptins其中,參數(shù)Sure是記錄源;參數(shù)Ativennttin指定在哪個(gè)連接中翻開該記錄集;參

8、數(shù)ursrType指定翻開Rerdset時(shí)使用的游標(biāo);參數(shù)LkType指定翻開記錄集時(shí)應(yīng)該使用的鎖定類型;參數(shù)ptins指定參數(shù)Sure的種類。主要代碼如下:HRESULThr;_variant_tvar;_RerdsetPtrpRerdset;/定義記錄集指針hr=pRerdset.reatEinstane(_uuidf(Rerdset);/實(shí)例化記錄集指針Stringstrsql;strsql=SELET*FRnaetable/定義并初始化SQL語句字符串,naetable為表名try/利用pen函數(shù)執(zhí)行SQL命令,獲得查詢結(jié)果記錄集hr=pRerdset-pen(_variant_t(s

9、trsql),_pnnetin.GetInterfaePtr(),adpenDynai,adLkptiisti,addText);if(hr)hile(!pRerdset-adEF)/獲取第1列的值,從0開場(chǎng)計(jì)數(shù),也可以直接給出列的名字var=pRerdset-Getllet(lng)0);var=pRerdset-Getllet(“Nae);pRerdset-veNext();/挪動(dòng)當(dāng)前記錄到下一條記錄pRerdset-veFirst();/挪動(dòng)到首條記錄pRerdset-Delete(adAffeturent);/刪除當(dāng)前記錄pRerdset-AddNe();/添加新記錄pRerdset-

10、Putllet(“ID,_variant_t(lng)72);pRerdset-Putllet(“Nae,_variant_t(“小王);pRerdset-veNext();pRerdset-Putllet(“Nae,_variant_t(“小周);/修改Nae字段的值pRerdset-Update/保存到數(shù)據(jù)庫中elseAfxessageBx(“penrerdsetfail);return;ath(_errr*e)AfxessageBx(e-Errressage();return;pRerdset-lse();pRerdset=NULL;3.4使用and對(duì)象操作數(shù)據(jù)庫and對(duì)象定義了將對(duì)數(shù)據(jù)源執(zhí)行的指定命令。使用and對(duì)象的流程和記錄集對(duì)象類似,首先聲明_andPtr變量;實(shí)例化變量;設(shè)置對(duì)象的某些屬性值;調(diào)用Exeute方法執(zhí)行命令。所以,這里就不給出代碼了。4完畢語AD是應(yīng)用級(jí)的編程接口,它以LEDB為根底,對(duì)LEDB進(jìn)展了封裝。它的主要優(yōu)點(diǎn)是易于使用、速度快、內(nèi)存支出少和使用較少的網(wǎng)絡(luò)流量。AD技術(shù)是微軟大力支持和開展的技術(shù),對(duì)于致力與Visual+的程序員來說,理解和掌握AD技術(shù)具有深遠(yuǎn)的意義。參考文獻(xiàn)1原奕等編著.Visual+

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論