• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            隨筆 - 25, 文章 - 0, 評(píng)論 - 6, 引用 - 0
            數(shù)據(jù)加載中……

            Vc++ 數(shù)據(jù)庫(kù)編程

            ODBC開放數(shù)據(jù)庫(kù)互連(Open Database Connectivity)是微軟公司開放服務(wù)結(jié)構(gòu)(WOSA,Windows Open Services Architecture)中有關(guān)數(shù)據(jù)庫(kù)的一個(gè)組成部分,它建立了一組規(guī)范,并提供了一組對(duì)數(shù)據(jù)庫(kù)訪問(wèn)的標(biāo)準(zhǔn)API(應(yīng)用程序編程接口)。這些API利用SQL來(lái)完成其大部分任務(wù)。ODBC本身也提供了對(duì)SQL語(yǔ)言的支持,用戶可以直接將SQL語(yǔ)句送給ODBC。

            ADO (ActiveX Data Objects) 是微軟公司的一個(gè)用于存取數(shù)據(jù)源的COM組件。它提供了編程語(yǔ)言和統(tǒng)一數(shù)據(jù)訪問(wèn)方式OLE DB的一個(gè)中間層。允許開發(fā)人員編寫訪問(wèn)數(shù)據(jù)的代碼而不用關(guān)心數(shù)據(jù)庫(kù)是如何實(shí)現(xiàn)的,而只用關(guān)心到數(shù)據(jù)庫(kù)的連接。訪問(wèn)數(shù)據(jù)庫(kù)的時(shí)候,關(guān)于SQL的知識(shí)不是必要的,但是特定數(shù)據(jù)庫(kù)支持的SQL命令仍可以通過(guò)ADO中的命令對(duì)象來(lái)執(zhí)行。ADO被設(shè)計(jì)來(lái)繼承微軟早期的數(shù)據(jù)訪問(wèn)對(duì)象層,包括RDO (Remote Data Objects) 和DAO(Data Access Objects)。

            使用#import方法對(duì)ADO進(jìn)行操作
            在#import中,你需要提供所包含的類型庫(kù)的路徑和名稱,它能夠自動(dòng)產(chǎn)生一個(gè)對(duì)GUIDs的定義,同時(shí)對(duì)自動(dòng)生成對(duì)ADO對(duì)象的封裝。

            還能夠列舉它在類型庫(kù)中所能找到的類型,對(duì)任何你所引用的類型庫(kù),VC++會(huì)在編譯的時(shí)候自動(dòng)生成兩個(gè)文件:
            一個(gè)頭文件(.tlh),它包含了列舉的類型和對(duì)類型庫(kù)中對(duì)象的定義。
            一個(gè)實(shí)現(xiàn)文件(.tli)對(duì)類型庫(kù)對(duì)象模型中的方法產(chǎn)生封裝。

            #import "c:\Program Files\common files\system\ado\msado15.dll" no_namespace rename("EOF","adoEOF")
            /*VC++會(huì)自動(dòng)產(chǎn)生msado15.tlh和msado15.tli兩個(gè)文件。no_namespace意味著你不需要在初始化變量的時(shí)候引用名字空間。對(duì)EOF進(jìn)行該名,是必要的,因?yàn)榈湫偷腣C++應(yīng)用都已經(jīng)定義了EOF作為常數(shù)-1*/
                   CoInitialize(NULL);
            /*CoInitialize是 Windows提供的API函數(shù),用來(lái)告訴 Windows以單線程的方式創(chuàng)建com對(duì)象。參數(shù)被保留,且必須為NULL。CoInitialize并不裝載COM 庫(kù),它只用來(lái)初始化當(dāng)前線程使用什么樣的套間。使用這個(gè)函數(shù)后,線程就和一個(gè)套間建立了對(duì)應(yīng)關(guān)系,線程在此套間運(yùn)行。CoInitialize和CoUninitialize必須成對(duì)使用。*/
                      _ConnectionPtr m_pConnection(_uuidof(Connection));         
            //使用智能指針產(chǎn)生一個(gè)連接指針
                     _RecordsetPtr m_pRecordset(_uuidof(Recordset));            //使用智能指針產(chǎn)生一個(gè)記錄集指針
             try{
                      m_pConnection
            ->Open("DSN=Student","","",0);          //建立連接,DSN(Data Source Name )是你要連接ODBC數(shù)據(jù)源的名稱
                      m_pRecordset = m_pConnection->Execute("select * from Student",NULL,adCmdText);           //執(zhí)行查詢語(yǔ)句
              while(!m_pRecordset->adoEOF)
              {
                 _variant_t TheValue;   
            //_variant_t封裝并管理VARIANT數(shù)據(jù)類型,是COM中使用的數(shù)據(jù)類型,COM是Component Object Model(組件對(duì)象模型)
                 TheValue = m_pRecordset->GetCollect("Sname");         //獲取表中字段為“Sname”的值
                 m_pRecordset->MoveNext();          //移動(dòng)到下一條記錄
              }
             }
            catch(_com_error e)
             {
                  AfxMessageBox(e.ErrorMessage());
             }
                 m_pRecordset
            ->Close();
                 m_pConnection
            ->Close();
                 m_pRecordset 
            = NULL;
                 m_pConnection 
            = NULL;
                 CoUninitialize(); 

            posted on 2013-03-05 13:41 chenjt3533 閱讀(256) 評(píng)論(0)  編輯 收藏 引用 所屬分類: C/C++

            久久99精品久久久久婷婷| 狠狠精品久久久无码中文字幕 | 国产精品久久久久蜜芽| 久久久久久午夜精品| 精品久久久久久亚洲精品| 国产成人精品久久综合| 久久夜色精品国产亚洲| 狠狠色丁香久久综合婷婷| 无码乱码观看精品久久| 69国产成人综合久久精品| 久久久WWW成人免费毛片| 欧美牲交A欧牲交aⅴ久久| 开心久久婷婷综合中文字幕| 久久久精品人妻一区二区三区蜜桃| 久久精品一区二区三区不卡| 一本色道久久88综合日韩精品 | 狠狠综合久久综合88亚洲| 一本伊大人香蕉久久网手机| 久久伊人五月丁香狠狠色| 91久久成人免费| 国产一级持黄大片99久久| 无遮挡粉嫩小泬久久久久久久| 久久福利片| 狠狠精品久久久无码中文字幕| 国产精品欧美久久久天天影视 | 色婷婷久久综合中文久久蜜桃av| 久久婷婷人人澡人人| 亚洲成色999久久网站| 精品国产一区二区三区久久| 成人妇女免费播放久久久| 2021国内精品久久久久久影院| 久久久久久无码国产精品中文字幕| 国产成人精品久久免费动漫| 久久精品aⅴ无码中文字字幕重口 久久精品a亚洲国产v高清不卡 | 99久久国产免费福利| 国产亚洲欧美成人久久片| 国产欧美一区二区久久| 国产午夜久久影院| 国产成人精品久久一区二区三区av| 欧美777精品久久久久网| 久久综合狠狠综合久久激情 |