青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

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 閱讀(412) 評論(0)  編輯 收藏 引用 所屬分類: VC/MFC

<2025年9月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

常用鏈接

留言簿(7)

隨筆分類

隨筆檔案

文章分類

文章檔案

相冊

編程資源

不務正業

找工作

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美日韩在线一区二区| 亚洲人www| 国产精品稀缺呦系列在线| 欧美日韩18| 欧美屁股在线| 国产精品毛片| 国产一区白浆| 亚洲电影观看| 日韩亚洲一区在线播放| 亚洲天堂免费在线观看视频| 午夜久久久久久久久久一区二区| 午夜伦欧美伦电影理论片| 久久精品动漫| 亚洲欧洲精品一区二区三区| 日韩天堂av| 欧美一区二区三区四区在线观看 | 亚洲啪啪91| 99视频日韩| 久久精品99国产精品日本| 免费看成人av| 国产精品外国| 亚洲精品综合精品自拍| 欧美一区二区精品在线| 欧美国产三级| 先锋影音久久| 欧美日韩成人在线观看| 国产亚洲欧美日韩美女| 亚洲免费播放| 久久综合中文字幕| 一区二区三区产品免费精品久久75| 欧美影片第一页| 乱中年女人伦av一区二区| 国产精品久久久久久久久免费| 亚洲第一黄网| 久久久噜噜噜久久| 亚洲免费在线观看| 欧美日韩亚洲系列| 亚洲人成人一区二区在线观看| 欧美怡红院视频| 中文日韩欧美| 欧美日韩免费一区| 亚洲肉体裸体xxxx137| 久久嫩草精品久久久精品| 一区二区三区欧美在线观看| 久久综合九色九九| 韩日视频一区| 久久九九精品| 性欧美大战久久久久久久免费观看| 欧美日韩激情网| 亚洲毛片av| 91久久综合亚洲鲁鲁五月天| 噜噜爱69成人精品| 亚洲国产成人精品女人久久久| 久久精品综合| 欧美在线免费| 影音先锋亚洲电影| 欧美精品一区二区三区很污很色的| 欧美成人日本| 亚洲精品日韩久久| 欧美激情a∨在线视频播放| 久久久久久久成人| 一区在线播放视频| 欧美 日韩 国产一区二区在线视频| 一区二区冒白浆视频| 国产伦精品一区二区三区高清| 黄色欧美日韩| 久久夜色精品国产欧美乱| 国产精品区一区二区三区| 日韩一区二区电影网| 亚洲国产婷婷香蕉久久久久久| 欧美va亚洲va香蕉在线| 日韩午夜精品| 中国成人黄色视屏| 国产老肥熟一区二区三区| 久久本道综合色狠狠五月| 性欧美1819sex性高清| 精品88久久久久88久久久| 欧美高清在线观看| 欧美日韩网站| 欧美中文字幕在线播放| 久久嫩草精品久久久精品一| 亚洲激情国产精品| 99精品国产高清一区二区| 国产精品一级二级三级| 久久综合九色欧美综合狠狠| 欧美gay视频激情| 亚洲免费视频在线观看| 久久精品国产99| 日韩午夜激情| 西瓜成人精品人成网站| 亚洲欧洲精品一区| 亚洲自拍都市欧美小说| 亚洲国产精品精华液2区45| 亚洲美女淫视频| 国产一区二区精品久久| 亚洲成色777777女色窝| 国产精品国产三级国产| 欧美成人一区二区三区片免费| 国产精品成人免费精品自在线观看 | 亚洲综合成人在线| 亚洲高清av在线| 亚洲午夜激情网站| 亚洲人成人77777线观看| 亚洲一二三区在线观看| 亚洲国产婷婷| 欧美一区二区免费| 亚洲天堂久久| 欧美激情精品久久久久久蜜臀| 久久av老司机精品网站导航| 欧美精品一区二区在线观看| 久久亚洲国产精品日日av夜夜| 欧美视频在线观看 亚洲欧| 欧美国产日韩免费| 国产亚洲一区二区三区在线观看| 欧美在线影院| 日韩天堂在线视频| 亚洲人体偷拍| 国产精品99久久久久久白浆小说| 美女黄网久久| 国产精品免费观看在线| 亚洲电影在线播放| 国内外成人免费激情在线视频 | 久久成人国产精品| 欧美午夜在线一二页| 亚洲激情视频| 亚洲国产欧美国产综合一区| 欧美一区视频在线| 欧美一区成人| 国产目拍亚洲精品99久久精品| 在线视频欧美精品| 亚洲午夜激情网页| 欧美精品一区二区三区久久久竹菊| 嫩草伊人久久精品少妇av杨幂| 国产曰批免费观看久久久| 羞羞色国产精品| 欧美在线视频一区二区| 国产美女一区| 久久九九全国免费精品观看| 久久青草欧美一区二区三区| 黑人巨大精品欧美一区二区| 欧美专区日韩视频| 久久全球大尺度高清视频| 国内精品久久久| 久久午夜羞羞影院免费观看| 巨乳诱惑日韩免费av| 在线欧美一区| 欧美精品系列| 亚洲社区在线观看| 欧美一区二区三区婷婷月色| 国产午夜精品美女视频明星a级| 欧美在线啊v一区| 欧美大片专区| 一区二区三区久久网| 国产精品久久| 久久精品国产精品 | 国产精品日本| 欧美一区二区国产| 牛牛影视久久网| 一二三四社区欧美黄| 欧美日韩日日夜夜| 亚洲综合社区| 欧美成在线观看| 亚洲影院在线| 韩国久久久久| 欧美日韩亚洲高清| 久久精品99久久香蕉国产色戒 | 99香蕉国产精品偷在线观看| 欧美一区2区三区4区公司二百| 亚洲第一久久影院| 欧美日韩一区二区三区| 久久精品国产99国产精品澳门| 亚洲电影免费在线| 香蕉尹人综合在线观看| 亚洲视频一区| 亚洲欧美日韩精品久久奇米色影视| 久久国产免费| 亚洲每日更新| 久久久青草婷婷精品综合日韩| 亚洲激情图片小说视频| 国产精品美女诱惑| 欧美**人妖| 欧美亚洲一区在线| 亚洲精选视频免费看| 久久影院午夜论| 亚洲自拍偷拍一区| 亚洲乱码国产乱码精品精可以看| 国产免费观看久久黄| 欧美日韩一区二区三区四区在线观看 | 久久综合给合| 欧美一级理论性理论a| 亚洲精品日韩久久| 激情婷婷亚洲| 国产精品视频在线观看| 欧美剧在线观看| 久久久久久日产精品| 亚洲自拍偷拍视频| 在线一区视频| a4yy欧美一区二区三区| 亚洲人www| 亚洲欧洲日夜超级视频|