• <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>
            posts - 19,  comments - 21,  trackbacks - 0
            一、 引言

              數據庫屬于最流行的應用程序之一,幾乎每個商業部門都使用數據庫來記錄、管理各種各樣的數據。在VC下我們可以在創建工程時選擇數據庫支持,并選定數據源和相關的表,并選擇CRecordView作為我們這個程序的基類,這樣做可以毫不費力的將應用程序和數據庫建立了關聯,而幾乎不用編什么代碼,但這樣做的前提是在新建工程時已明確知道用到哪個數據庫,并且有相關的數據庫。事實上我們往往有許多已做好的應用程序和類,其功能除了未和數據源建立關聯外以基本滿足要求,我們只要在其基礎上添加ODBC接口,使之與數據庫建立關聯即可,這樣做避免了與數據庫無關部分代碼的重新編寫所造成的重復性操作,大大提高了代碼的重用性和利用率。所以在普通程序上通過添加ODBC應用而與數據庫建立關聯的方法是完全行之有效的。

              二、 ODBC技術

              ODBC(Open Database Conectivity 開放式數據庫互聯)技術,作為Microsoft公司對數據庫進行訪問的標準應用程序接口(API)和Windows開放式服務體系結構OSA的一個重要組成部分已廣為眾多的Windows程序員所熟悉、認可。ODBC的工作依賴于數據庫制造商提供的驅動程序,使用ODBC API的時候,Windows的ODBC管理程序,把數據庫訪問的請求傳遞給正確的驅動程序,驅動程序再使用SQL語句指示DBMS完成數據庫訪問工作,因此,ODBC的存在為我們開發應用數據庫程序提供了非常強大的能力和靈活性。

              三、 程序示例

              (一)打開Visual C++,在"File"菜單上點選"New…",然后在彈出的"New"對話框中選定"MFC AppWizard(exe)"類的項目,"Project name"為Normal,按下OK鍵,下一Step 1屏幕中選"Single document"單文檔支持,用到后面的選項除在最后一步選擇"CFormView"作為本工程視類的基類外均為確省值,此時即可按下Finish鍵,結果系統將生成一個新的項目Normal。

              我們就將此工程當做原有的工程,接下來我們便在此工程基礎上對其添加ODBC應用,使該工程能同數據源建立關聯,能對數據庫中的數據進行操作和管理。

              (二)打開"控制面板"上的"ODBC (32bits)",對數據源進行注冊。為了使ODBC能與數據庫一起工作,就必須把數據庫注冊到ODBC驅動程序管理器,這項工作可以通過定義一個DSN或數據源名字來完成。在彈出的"ODBC數據源管理器"中選擇"User DSN"屬性頁,點擊"Add…"按鈕。選擇"Microsoft Access Driver(*.mdb)"作為數據源的驅動器,點擊"完成"按鈕。在彈出的"ODBC Microsoft Access 97 Setup"對話框中在"Data Source Name:"欄添入RP97,"Description:"欄只起注釋說明的作用,可以不填,然后點擊"Select…"按鈕,選擇所要注冊的數據源,然后點擊"OK"就完成了對數據源的注冊,到這一步,本機上的任意程序只要通過ODBC接口和數據源名"RP97"就能完成對數據庫的訪問了。

              (三)在VC的"Workspace"活動窗口中選擇"FileView"屬性頁,打開標準框架頭文件"StdAfx.h",并在最后一個#include后面添加對"afxdb.h"的引用:#include <afxdb.h>

              (四) 在"Workspace"活動窗口中選擇"ClassView"屬性頁,在"Normal Classes"上右鍵,選"New Class…",在彈出的"New Class"對話框的"Base Class"欄選擇"CRecordSet"做為新添加的類的基類,在"Name"欄填寫類名"CODBCSet",點擊"OK",在隨后彈出的對話框的"ODBC"欄選擇剛注冊的"RP97"數據源,點擊"OK"后選擇該數據庫的一個表,點擊"OK"在"ClassView"里就多了一個以CRecordSet為基類的新類"CODBCSet"。下面三個函數完成了數據庫各級元素的綁定工作:

            CString CODBCSet::GetDefaultConnect()
            {
             
            return _T("ODBC;DSN=RP97");
            }


            CString CODBCSet::GetDefaultSQL()
            {
             
            return _T("[單據表]");
            }


            void CODBCSet::DoFieldExchange(CFieldExchange* pFX)
            {
             
            //{{AFX_FIELD_MAP(CODBCSet)
             pFX->SetFieldType(CFieldExchange::outputColumn);
             RFX_Text(pFX, _T(
            "[單據ID]"), m_column1);
             RFX_Text(pFX, _T(
            "[單據名稱]"), m_column2);
             RFX_Text(pFX, _T(
            "[報帳人]"), m_column3);
             
            //}}AFX_FIELD_MAP
            }
             

              (五)按同樣的方法再添加一個基于"generic CWnd"的新類"CConnectDB"。在該類的源文件里添加對"ODBCSet.h"的引用:#include "ODBCSet.h"。在該類的頭文件的"class CconnectDB"前添加class CODBCSet;并在該類里添加公有型成員變量和函數:

            CDatabase m_dbData;
            CODBCSet
            * m_pSet;
            void CConnectDB::Initial()
            {
             
            //打開數據源RP97
             CString os=_T("odbc; dsn=RP97");
             m_dbData.Open(NULL,FALSE,FALSE,
            0);
             m_pSet
            =new CODBCSet(&m_dbData);
             
            //通過SQL結構化查詢語言打開RP97里的單據表
             CString sql="SELECT * FROM 單據表";
             m_pSet
            ->Open(AFX_DB_USE_DEFAULT_TYPE,sql);
            }



              (六)在Form上添加一個"測試"按鈕及其響應函數OnTest():

            void CNormalView::OnTest() 
            {
             CConnectDB connectDB;
             
            //執行完Initial()后m_pSet指針才不為空,方可安全使用。
             connectDB.Initial();
             
            if(connectDB.m_pSet==NULL)
              
            return;
             connectDB.m_pSet
            ->MoveFirst();
             CString str
            =connectDB.m_pSet->m_column3;
             AfxMessageBox(str);
            }
             

              最后在該文件開始處添加兩個引用:

            #include 
            "ConnectDB.h"
            #include 
            "ODBCSet.h" 

              四、 運行與測試

              編譯運行程序,點擊"測試"按鈕,就會將"RP97"數據庫的"單據表"的第一條記錄的"報帳人"字段所在的內容通過對話框彈出來。

              小結:

              本程序的關鍵在于對數據庫指針m_pSet的獲取,當類CConnectDB 的成員函數Initial()被執行完時,m_pSet就已被獲取到了,而在此之前該指針是空的,是不能使用的,所以在實際應用中必須保證在使用m_pSet之前調用過函數Initial()。當m_pSet被獲取到之后,就可以想其他ODBC應用程序一樣使用CrecordSet類里的各種函數對數據庫進行各種需要的操作和管理了。
            posted on 2005-11-24 13:42 halCode 閱讀(390) 評論(0)  編輯 收藏 引用 所屬分類: VC/MFC

            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            常用鏈接

            留言簿(7)

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            相冊

            編程資源

            不務正業

            找工作

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            精品一久久香蕉国产线看播放| 热re99久久6国产精品免费| 久久96国产精品久久久| 久久香蕉国产线看观看99| 亚洲国产成人久久综合野外| 亚洲午夜久久久久久噜噜噜| 99久久www免费人成精品| 伊人色综合久久天天网| 日本免费久久久久久久网站| 亚洲欧美国产日韩综合久久| 国产V亚洲V天堂无码久久久| 亚洲欧美一级久久精品| 久久精品国产亚洲网站| 午夜精品久久久久久久无码| 欧美综合天天夜夜久久| 三级三级久久三级久久| 狠狠精品干练久久久无码中文字幕 | 中文字幕人妻色偷偷久久| 国产精品99久久久久久www| 久久人妻少妇嫩草AV蜜桃| 国产A级毛片久久久精品毛片| 一本色道久久88精品综合| 亚洲国产精品综合久久一线| 99热成人精品免费久久| 成人免费网站久久久| 色欲久久久天天天综合网精品 | 日产精品久久久久久久| 久久青青草原精品国产不卡| 久久电影网一区| 亚洲一本综合久久| 国产精品福利一区二区久久| 久久久久亚洲av无码专区导航| 久久久久亚洲AV成人网人人网站| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 国产精品免费久久久久久久久| 好久久免费视频高清| 久久久久亚洲av无码专区导航| 久久久久高潮毛片免费全部播放 | 99久久婷婷国产综合亚洲| 久久久久久夜精品精品免费啦 | 99久久精品免费看国产|