• <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, 評論 - 6, 引用 - 0
            數據加載中……

            Vc++ 數據庫編程

            ODBC開放數據庫互連(Open Database Connectivity)是微軟公司開放服務結構(WOSA,Windows Open Services Architecture)中有關數據庫的一個組成部分,它建立了一組規范,并提供了一組對數據庫訪問的標準API(應用程序編程接口)。這些API利用SQL來完成其大部分任務。ODBC本身也提供了對SQL語言的支持,用戶可以直接將SQL語句送給ODBC。

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

            使用#import方法對ADO進行操作
            在#import中,你需要提供所包含的類型庫的路徑和名稱,它能夠自動產生一個對GUIDs的定義,同時對自動生成對ADO對象的封裝。

            還能夠列舉它在類型庫中所能找到的類型,對任何你所引用的類型庫,VC++會在編譯的時候自動生成兩個文件:
            一個頭文件(.tlh),它包含了列舉的類型和對類型庫中對象的定義。
            一個實現文件(.tli)對類型庫對象模型中的方法產生封裝。

            #import "c:\Program Files\common files\system\ado\msado15.dll" no_namespace rename("EOF","adoEOF")
            /*VC++會自動產生msado15.tlh和msado15.tli兩個文件。no_namespace意味著你不需要在初始化變量的時候引用名字空間。對EOF進行該名,是必要的,因為典型的VC++應用都已經定義了EOF作為常數-1*/
                   CoInitialize(NULL);
            /*CoInitialize是 Windows提供的API函數,用來告訴 Windows以單線程的方式創建com對象。參數被保留,且必須為NULL。CoInitialize并不裝載COM 庫,它只用來初始化當前線程使用什么樣的套間。使用這個函數后,線程就和一個套間建立了對應關系,線程在此套間運行。CoInitialize和CoUninitialize必須成對使用。*/
                      _ConnectionPtr m_pConnection(_uuidof(Connection));         
            //使用智能指針產生一個連接指針
                     _RecordsetPtr m_pRecordset(_uuidof(Recordset));            //使用智能指針產生一個記錄集指針
             try{
                      m_pConnection
            ->Open("DSN=Student","","",0);          //建立連接,DSN(Data Source Name )是你要連接ODBC數據源的名稱
                      m_pRecordset = m_pConnection->Execute("select * from Student",NULL,adCmdText);           //執行查詢語句
              while(!m_pRecordset->adoEOF)
              {
                 _variant_t TheValue;   
            //_variant_t封裝并管理VARIANT數據類型,是COM中使用的數據類型,COM是Component Object Model(組件對象模型)
                 TheValue = m_pRecordset->GetCollect("Sname");         //獲取表中字段為“Sname”的值
                 m_pRecordset->MoveNext();          //移動到下一條記錄
              }
             }
            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 閱讀(265) 評論(0)  編輯 收藏 引用 所屬分類: C/C++

            国产精品成人久久久| 无码任你躁久久久久久| 天天爽天天狠久久久综合麻豆| 精品久久久久久久久免费影院| 久久天天躁夜夜躁狠狠躁2022| 久久久久高潮毛片免费全部播放| 99久久99久久久精品齐齐| 激情五月综合综合久久69| 久久综合久久综合亚洲| www.久久99| 久久久久久久久波多野高潮| 精品少妇人妻av无码久久| 国内精品久久久久久久久| 人妻少妇久久中文字幕| 久久93精品国产91久久综合| 少妇内射兰兰久久| 看全色黄大色大片免费久久久| 99精品国产在热久久| 婷婷久久五月天| 久久强奷乱码老熟女网站| 色天使久久综合网天天| 蜜臀av性久久久久蜜臀aⅴ| 国内精品久久久久久久影视麻豆| 亚洲AV无码久久精品色欲| 久久久无码精品亚洲日韩软件| 久久精品国产91久久麻豆自制| 亚洲精品无码久久久影院相关影片 | 91久久香蕉国产熟女线看| 久久亚洲sm情趣捆绑调教 | 国产精品视频久久| 久久久久久精品无码人妻| 久久天天躁狠狠躁夜夜2020| 欧美精品一本久久男人的天堂| 精品久久人妻av中文字幕| 亚洲AV乱码久久精品蜜桃| 久久亚洲精品无码aⅴ大香 | 亚洲国产成人久久精品99| 夜夜亚洲天天久久| 精品久久久久中文字幕一区| 91精品婷婷国产综合久久| 91超碰碰碰碰久久久久久综合|