中文字幕在线一区二区在线,久久久精品免费观看国产,无码日日模日日碰夜夜爽,天堂av在线最新版在线,日韩美精品无码一本二本三本,麻豆精品三级国产国语,精品无码AⅤ片,国产区在线观看视频

      vc++中的ADO的應用

      時間:2024-08-22 14:50:41 ADO 我要投稿
      • 相關推薦

      vc++中的ADO的應用

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

        關鍵詞ADO;數據庫;應用程序的開發;VC++

        1引言

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

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

        2VC++中使用ADO開發數據庫應用程序一般步驟

        在VC++中使用ADO開發數據庫應用程序一般包括以下步驟:

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

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

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

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

        3ADO使用實例

        3.1引入ADO動態鏈接庫,初始化COM庫環境

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

        #import”c:programfilescommonfilessystemadomaado15.dll”

        no_namespacerename(“EOF”,”adoEOF”)

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

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

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

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

        3.2創建ADO與數據庫的連接

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

        HRESULTOpen(_bstr_tConnectionString,_bstr_tUserID,_bstr_tPassword,longOptions)

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

        主要代碼如下:

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

        //初始化數據庫連接

        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)對象操作數據庫

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

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

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

        主要代碼如下:

        HRESULThr;

        _variant_tvar;

        _RecordsetPtrpRecordset;//定義記錄集指針

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

        CStringstrsql;

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

        try

        {//利用Open函數執行SQL命令,獲得查詢結果記錄集

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

        adLockOptimistic,adCmdText);

        if(hr)

        {

        while(!pRecordset->adoEOF)

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

        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//保存到數據庫中

        }

        else

        {

        AfxMessageBox(“Openrecordsetfail”);

        return;

        }

        }

        catch(_com_error*e)

        {

        AfxMessageBox(e->ErrorMessage());

        return;

        }

        pRecordset->Close();

        pRecordset=NULL;

        3.4使用Command對象操作數據庫

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

        4結束語

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

        參考文獻

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

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

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

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

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

      有關ADO與ADO.NET的區別與介紹03-29

      刺繡在服裝中的應用03-22

      CAD在設計施工中的應用03-04

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

      Excel在審計中的應用06-22

      CAD在工程制圖課程中的應用03-30

      CAD在環境工程中的應用03-03

      油脂在烘焙食品技術中的應用03-11

      漢字在平面設計中的應用03-06

      主站蜘蛛池模板: 欧美亚洲日韩国产人成在线播放 | 美腿丝袜美腿国产在线| 无码一区二区三区网站| 亚洲中文字幕久爱亚洲伊人| 麻豆精品av国产一区久久| 国产一区二区三区在线免费观看| AV熟妇导航网| 好爽~又到高潮了毛片视频| 濮阳市| 湖南省| 湘乡市| 普定县| 宝兴县| 南江县| 巫溪县| 扶余县| 论坛| 69av视频在线| 97色综合| 久久国产亚洲一区二区三区| 汾阳市| 日韩av无卡无码午夜观看| 国产精品福利久久香蕉中文| 国产品精品久久久久中文| 青冈县| 国产成人精品cao在线| 国产女主播福利一二区| 宁晋县| 亚洲国产精品久久久久婷婷软件| 日韩精品极品视频在线观看蜜桃| 国产啪精品视频网站免| 亚洲区一区二区中文字幕| 免费大学生国产在线观看p| 黑丝美女喷水在线观看| 中文字幕乱码中文乱码毛片| 精品国产又大又黄又粗av| 精品国产亚洲av麻豆尤物| 国产精品三级国产专不| 日本在线观看视频一区二区三区| 久久久久成人精品免费播放网站| 丰满熟妇人妻av无码区|