亚洲AV日韩AⅤ综合手机在线观看,激情婷婷久久综合色,欧美色五月婷婷久久,久久国产精品99久久人人澡

  • <abbr id="uk6uq"><abbr id="uk6uq"></abbr></abbr>
  • <tbody id="uk6uq"></tbody>
  • vc++中的ADO的應用

    時間:2023-03-29 14:46:20 ADO 我要投稿
    • 相關推薦

    vc++中的ADO的應用

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

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

      1引言

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

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

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

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

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

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

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

     。4)使用完后關閉連接,釋放對象所占的資源。

      3ADO使用實例

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

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

      #import”c:programfilescommonfilessystemadomaado15.dll”

      no_namespacerename(“EOF”,”adoEOF”)

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

      ADO是基于COM技術的,所以,在應用程序調用ADO前,必須初始化COM庫環(huán)境。ADO使用結束后需要關閉庫,釋放初始化加載的動態(tài)鏈接庫。

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

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

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

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

      HRESULTOpen(_bstr_tConnectionString,_bstr_tUserID,_bstr_tPassword,longOptions)

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

      主要代碼如下:

      HRESULT_ConnectionPtrm_pConnection;//連接對象智能指針

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

      HRESULThr;

      try

      {

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

      if(SUCCEEDED(hr))

      {

      //設置連接串屬性為UDL文件

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

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

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

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

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

      主要代碼如下:

      HRESULThr;

      _variant_tvar;

      _RecordsetPtrpRecordset;//定義記錄集指針

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

      CStringstrsql;

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

      try

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

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

      adLockOptimistic,adCmdText);

      if(hr)

      {

      while(!pRecordset->adoEOF)

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

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

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

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

      }

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

      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//保存到數(shù)據(jù)庫中

      }

      else

      {

      AfxMessageBox(“Openrecordsetfail”);

      return;

      }

      }

      catch(_com_error*e)

      {

      AfxMessageBox(e->ErrorMessage());

      return;

      }

      pRecordset->Close();

      pRecordset=NULL;

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

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

      4結束語

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

      參考文獻

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

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

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

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

    【vc++中的ADO的應用】相關文章:

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

    色彩在設計中的應用方法12-19

    簡單談談CAD中布局的應用08-24

    樹籬在園林設計中的應用10-28

    GIS在景觀設計中的應用08-14

    圖形在平面設計中的應用04-15

    網(wǎng)絡技術在印刷中的應用技巧06-18

    環(huán)境設計中色彩的配色應用09-11

    半聲練習在聲樂訓練中的應用08-13

    廣告設計中幽默手法的應用08-13