亚洲国产日韩欧美在线a乱码,国产精品路线1路线2路线,亚洲视频一区,精品国产自,www狠狠,国产情侣激情在线视频免费看,亚洲成年网站在线观看

vc++中的ADO的應(yīng)用

時(shí)間:2023-03-29 14:46:20 ADO 我要投稿
  • 相關(guān)推薦

vc++中的ADO的應(yīng)用

  摘要介紹了ADO的特點(diǎn)以及在VC++中如何通過ADO開發(fā)數(shù)據(jù)庫(kù)應(yīng)用程序。ADO是開發(fā)訪問OLE數(shù)據(jù)庫(kù)應(yīng)用程序所使用的一種數(shù)據(jù)庫(kù)訪問組件,是一種可以訪問各種數(shù)據(jù)類型的連接機(jī)制。它不僅可以通過OLEDB、ODBC訪問數(shù)據(jù)庫(kù),還可以使用幾乎任何一種數(shù)據(jù)源,如SQLServer、Oracle、Access、Excel和文本文件、圖形文件等。ADO基于OLEDB,提供統(tǒng)一的數(shù)據(jù)訪問接口,使用簡(jiǎn)單,容易掌握。

  關(guān)鍵詞ADO;數(shù)據(jù)庫(kù);應(yīng)用程序的開發(fā);VC++

  1引言

  ADO是Microsoft公司新的數(shù)據(jù)訪問技術(shù),由于它是基于OLEDB接口上實(shí)現(xiàn)的COM對(duì)象,其性能和易用性都達(dá)到了極佳水平。ADO并不與數(shù)據(jù)庫(kù)直接打交道,而是要通過ODBC驅(qū)動(dòng)程序或OLEDB連接字符串來(lái)操作數(shù)據(jù)庫(kù)。ODBC或OLEDB是應(yīng)用程序與數(shù)據(jù)庫(kù)進(jìn)行連接通信的接口,其作用是將特定類型數(shù)據(jù)庫(kù)中的數(shù)據(jù)變換為標(biāo)準(zhǔn)而能統(tǒng)一操作的數(shù)據(jù)源。利用ADO對(duì)象并通過ODBC或OLEDB,可以實(shí)現(xiàn)對(duì)任意數(shù)據(jù)庫(kù)的存取和訪問。

  ADO模型包括7個(gè)對(duì)象,主要對(duì)象有3個(gè):Connection、Command和Recordset,可以被獨(dú)立創(chuàng)建和釋放。此外,還包括其他4個(gè)集合對(duì)象:Fields、Errors、Parameters和Properties。一個(gè)典型的ADO應(yīng)用程序使用Connection對(duì)象建立與數(shù)據(jù)源的連接,然后用一個(gè)Command對(duì)象給出對(duì)數(shù)據(jù)庫(kù)操作的命令,如插入數(shù)據(jù)或者查詢數(shù)據(jù)等,而Recordset用于對(duì)結(jié)果集進(jìn)行維護(hù)或者瀏覽等操作。其中Command命令所使用的語(yǔ)言與低層所對(duì)應(yīng)的OLEDB數(shù)據(jù)源有關(guān),不同的數(shù)據(jù)源可以使用不同的命令語(yǔ)言,對(duì)于關(guān)系數(shù)據(jù)庫(kù),通常使用SQL作為命令語(yǔ)言。

  2VC++中使用ADO開發(fā)數(shù)據(jù)庫(kù)應(yīng)用程序一般步驟

  在VC++中使用ADO開發(fā)數(shù)據(jù)庫(kù)應(yīng)用程序一般包括以下步驟:

  (1)初始化COM庫(kù),引入ADO庫(kù)定義文件。

 。2)用Connection對(duì)象連接數(shù)據(jù)庫(kù)。

 。3)利用建立好的連接,通過Connection、Command對(duì)象執(zhí)行SQL命令,或利用Recordset對(duì)象取得結(jié)果記錄集進(jìn)行處理、查詢。

  (4)使用完后關(guān)閉連接,釋放對(duì)象所占的資源。

  3ADO使用實(shí)例

  3.1引入ADO動(dòng)態(tài)鏈接庫(kù),初始化COM庫(kù)環(huán)境

  在使用VisualC++的MFC編程時(shí),MFC并沒有提供對(duì)ADO的封裝類,能夠支持ADO編程的是ADO的COM動(dòng)態(tài)鏈接庫(kù)文件msado*.dll,“*”位置的數(shù)字代表ADO庫(kù)的版本。引入該文件的方法是在stdafx.h頭文件中,添加如下代碼:

  #import”c:programfilescommonfilessystemadomaado15.dll”

  no_namespacerename(“EOF”,”adoEOF”)

  這些命令聲明在工程中使用ADO,但不使用ADO的名字空間,并為了避免沖突,將EOF改名為adoEOF。

  ADO是基于COM技術(shù)的,所以,在應(yīng)用程序調(diào)用ADO前,必須初始化COM庫(kù)環(huán)境。ADO使用結(jié)束后需要關(guān)閉庫(kù),釋放初始化加載的動(dòng)態(tài)鏈接庫(kù)。

  ::CoInitialize(NULL);//初始化COM庫(kù)

  ::CoUninitialize();//清除COM庫(kù)

  3.2創(chuàng)建ADO與數(shù)據(jù)庫(kù)的連接

  使用Connection對(duì)象打開連接,在引入的動(dòng)態(tài)鏈接庫(kù)生成的定義文件(msado15.tlh)中Open方法的定義如下:

  HRESULTOpen(_bstr_tConnectionString,_bstr_tUserID,_bstr_tPassword,longOptions)

  由于使用的數(shù)據(jù)庫(kù)軟件的不同,連接串的格式也有所不同,給程序員帶來(lái)很多麻煩。微軟公司提供了一種可視化的方法來(lái)解決這個(gè)問題,它提供了通用數(shù)據(jù)連接文件(UDL)來(lái)建立和測(cè)試ADO的連接屬性。

  主要代碼如下:

  HRESULT_ConnectionPtrm_pConnection;//連接對(duì)象智能指針

  //初始化數(shù)據(jù)庫(kù)連接

  HRESULThr;

  try

  {

  hr=m_pConnection.CreateInstance(_uuidof(Connection));//實(shí)例化連接對(duì)象

  if(SUCCEEDED(hr))

  {

  //設(shè)置連接串屬性為UDL文件

  m_pConnection->ConnectionString=”FileName=name.udl”;

  //設(shè)置等待連接打開的時(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)對(duì)象操作數(shù)據(jù)庫(kù)

  在ADO程序中,記錄集實(shí)際上緩存可從數(shù)據(jù)庫(kù)獲得的記錄,應(yīng)用程序可以從記錄集中獲得每條記錄的字段。Open方法在msado15.h文件中的定義如下:

  HRESULTOpen(const_variant_t&Source,const_variant_t&ActiveConntction,enumCursorTypeEnumCursorType,enumLockTypeEnumLockType,longoptions)

  其中,參數(shù)Source是記錄源;參數(shù)ActiveConntction指定在哪個(gè)連接中打開該記錄集;參數(shù)CursorType指定打開Recordset時(shí)使用的游標(biāo);參數(shù)LockType指定打開記錄集時(shí)應(yīng)該使用的鎖定類型;參數(shù)options指定參數(shù)Source的種類。

  主要代碼如下:

  HRESULThr;

  _variant_tvar;

  _RecordsetPtrpRecordset;//定義記錄集指針

  hr=pRecordset.CreateInstance(_uuidof(Recordset));//實(shí)例化記錄集指針

  CStringstrsql;

  strsql=”SELECT*FROMnametable”//定義并初始化SQL語(yǔ)句字符串,nametable為表名

  try

  {//利用Open函數(shù)執(zhí)行SQL命令,獲得查詢結(jié)果記錄集

  hr=pRecordset->Open(_variant_t(strsql),m_pConnection.GetInterfacePtr(),adOpenDynamic,

  adLockOptimistic,adCmdText);

  if(hr)

  {

  while(!pRecordset->adoEOF)

  {//獲取第1列的值,從0開始計(jì)數(shù),也可以直接給出列的名字

  var=pRecordset->GetCollect((long)0);

  var=pRecordset->GetCollect(“Name”);

  pRecordset->MoveNext();//移動(dòng)當(dāng)前記錄到下一條記錄

  }

  pRecordset->MoveFirst();//移動(dòng)到首條記錄

  pRecordset->Delete(adAffectCurent);//刪除當(dāng)前記錄

  pRecordset->AddNew();//添加新記錄

  pRecordset->PutCollect(“ID”,_variant_t((long)72));

  pRecordset->PutCollect(“Name”,_variant_t(“小王”));

  pRecordset->MoveNext();

  pRecordset->PutCollect(“Name”,_variant_t(“小周”));//修改Name字段的值

  pRecordset->Update//保存到數(shù)據(jù)庫(kù)中

  }

  else

  {

  AfxMessageBox(“Openrecordsetfail”);

  return;

  }

  }

  catch(_com_error*e)

  {

  AfxMessageBox(e->ErrorMessage());

  return;

  }

  pRecordset->Close();

  pRecordset=NULL;

  3.4使用Command對(duì)象操作數(shù)據(jù)庫(kù)

  Command對(duì)象定義了將對(duì)數(shù)據(jù)源執(zhí)行的指定命令。使用Command對(duì)象的流程和記錄集對(duì)象類似,首先聲明_CommandPtr變量;實(shí)例化變量;設(shè)置對(duì)象的某些屬性值;調(diào)用Execute方法執(zhí)行命令。所以,這里就不給出代碼了。

  4結(jié)束語(yǔ)

  ADO是應(yīng)用級(jí)的編程接口,它以O(shè)LEDB為基礎(chǔ),對(duì)OLEDB進(jìn)行了封裝。它的主要優(yōu)點(diǎn)是易于使用、速度快、內(nèi)存支出少和使用較少的網(wǎng)絡(luò)流量。ADO技術(shù)是微軟大力支持和發(fā)展的技術(shù),對(duì)于致力與VisualC++的程序員來(lái)說,了解和掌握ADO技術(shù)具有深遠(yuǎn)的意義。

  參考文獻(xiàn)

  [1]原奕等編著.VisualC++實(shí)踐與提高——數(shù)據(jù)庫(kù)開發(fā)與工程應(yīng)用篇[M].北京:中國(guó)鐵道出版社,2006

  [2]DavidSceppa著,石鈞,葛俊譯.ADO編程技術(shù)[M].北京:清華大學(xué)出版社,2001

  [3]厄拉森.MFCVisualC++6編程技術(shù)內(nèi)幕[M].北京:機(jī)械工業(yè)出版社,2000

  [4]江淑娟,蘇蕊等.利用ADO方法在C/S模式下實(shí)現(xiàn)遠(yuǎn)程數(shù)據(jù)訪問[J],山東科技大學(xué)學(xué)報(bào)(自然科學(xué)版),2003,22(1):73-75

【vc++中的ADO的應(yīng)用】相關(guān)文章:

OA系統(tǒng)在高校中的應(yīng)用05-10

色彩在設(shè)計(jì)中的應(yīng)用方法12-19

簡(jiǎn)單談?wù)凜AD中布局的應(yīng)用08-24

樹籬在園林設(shè)計(jì)中的應(yīng)用10-28

GIS在景觀設(shè)計(jì)中的應(yīng)用08-14

圖形在平面設(shè)計(jì)中的應(yīng)用04-15

網(wǎng)絡(luò)技術(shù)在印刷中的應(yīng)用技巧06-18

環(huán)境設(shè)計(jì)中色彩的配色應(yīng)用09-11

半聲練習(xí)在聲樂訓(xùn)練中的應(yīng)用08-13

廣告設(shè)計(jì)中幽默手法的應(yīng)用08-13