Visual_C++6.0數(shù)據庫編程_第1頁
Visual_C++6.0數(shù)據庫編程_第2頁
Visual_C++6.0數(shù)據庫編程_第3頁
Visual_C++6.0數(shù)據庫編程_第4頁
Visual_C++6.0數(shù)據庫編程_第5頁
已閱讀5頁,還剩23頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、第12章 Visual C+6.0數(shù)據庫編程,本節(jié)主要內容,數(shù)據庫的訪問和ODBC 使用ODBC創(chuàng)建數(shù)據庫應用程序 使用ADO創(chuàng)建數(shù)據庫應用程序,12.1 數(shù)據庫的訪問和ODBC,在使用Visual C+進行數(shù)據庫編程之前,先簡單介紹一些概念。,12.1.1 數(shù)據庫、數(shù)據庫模型和數(shù)據庫管理系統(tǒng),數(shù)據庫 數(shù)據庫是依照某種數(shù)據模型組織起來并存放二級存儲器中的數(shù)據集合。 數(shù)據庫具有如下特點:盡可能不重復,以最優(yōu)方式為某個特定組織的多種應用服務,其數(shù)據結構獨立于使用它的應用程序,對數(shù)據的增、刪、改和檢索由統(tǒng)一軟件進行管理和控制。,數(shù)據庫模型,現(xiàn)行的數(shù)據庫模型主要有以下四種: 層次結構模型 層次結構模型

2、實質上是一種有根結點的定向有序樹。按照層次模型建立的數(shù)據庫系統(tǒng)稱為層次模型數(shù)據庫系統(tǒng)。 網狀結構模型 按照網狀數(shù)據結構建立的數(shù)據庫系統(tǒng)稱為網狀數(shù)據庫系統(tǒng),用數(shù)學方法可將網狀數(shù)據結構轉化為層次數(shù)據結構。 關系結構模型 關系式數(shù)據結構把一些復雜的數(shù)據結構歸結為簡單的二元關系(即二維表格形式)。由關系數(shù)據結構組成的數(shù)據庫系統(tǒng)被稱為關系數(shù)據庫系統(tǒng)。 面向對象模型 隨著信息技術和市場的發(fā)展,對數(shù)據處理技術也提出了更高要求,為了能夠處理復雜對象數(shù)據就產生了面向對象數(shù)據模型。面向對象數(shù)據庫是面向對象概念和數(shù)據庫技術相結合產物。,數(shù)據庫管理系統(tǒng),數(shù)據庫管理系統(tǒng)(DBMS)為用戶提供對數(shù)據庫操作的各種命令、工具

3、及方法,包括數(shù)據庫的建立以及記錄的輸入、修改、檢索、顯示、刪除和統(tǒng)計等。 常用的數(shù)據庫系統(tǒng)有Access、mySQL、Sybase、SQL Server和Oracle等。這些DBMS 都提供了一個SQL 接口。,12.1.2 開放式數(shù)據庫接口ODBC,ODBC(Open Database Connectivity,開放數(shù)據庫互連)是微軟公司開放服務結構(WOSA,Windows Open Services Architecture)中有關數(shù)據庫的一個組成部分,它建立了一組規(guī)范,并提供了一組對數(shù)據庫訪問的標準API(應用程序編程接口)。這些API利用SQL來完成其大部分任務。ODBC本身也提供了

4、對SQL語言的支持,用戶可以直接將SQL語句送給ODBC。,開放式數(shù)據庫接口ODBC(Con),一個基于ODBC的應用程序對數(shù)據庫的操作不依賴任何DBMS,不直接與DBMS打交道,所有的數(shù)據庫操作由對應的DBMS的ODBC驅動程序完成。由此可見,ODBC的最大優(yōu)點是能以統(tǒng)一的方式處理所有的數(shù)據庫。,開放式數(shù)據庫接口ODBC(Con),一個完整的ODBC由下列幾個部件組成: 1. 應用程序(Application)。 2. ODBC管理器(Administrator):主要任務是管理安裝的ODBC驅動程序和管理數(shù)據源。 3. 驅動程序管理器(Driver Manager):對用戶是透明的。任務是

5、管理ODBC驅動程序,是ODBC中最重要的部件。 4. ODBC API:包含在動態(tài)庫中的一個函數(shù)集合、一個錯誤代碼集合、一個標準的SQL語句集合,用來調用DBMS中的數(shù)據。 5. ODBC 驅動程序(Database drivers):是一些DLL,提供了ODBC和數(shù)據庫之間的接口。 6. 數(shù)據源:數(shù)據源包含了數(shù)據庫位置和數(shù)據庫類型等信息,實際上是一種數(shù)據連接的抽象。,開放式數(shù)據庫接口ODBC(Con),應用程序要訪問一個數(shù)據庫,首先必須用ODBC管理器注冊一個數(shù)據源,管理器根據數(shù)據源提供的數(shù)據庫位置、數(shù)據庫類型及ODBC驅動程序等信息,建立起ODBC與具體數(shù)據庫的聯(lián)系。這樣,只要應用程序將

6、數(shù)據源名提供給ODBC,ODBC就能建立起與相應數(shù)據庫的連接。 在ODBC中,ODBC API不能直接訪問數(shù)據庫,必須通過驅動程序管理器與數(shù)據庫交換信息。,12.1.3 MFC ODBC 技術,MFC的ODBC類對較復雜的ODBC API進行了封裝,提供了簡化的調用接口,從而大大方便了數(shù)據庫應用程序的開發(fā)。,MFC ODBC 技術(Con),MFC 的ODBC 類主要包括如下5 類。 1. CDatabase類:主要功能是建立與數(shù)據源的連接,可以在整個應用程序中共享這些信息。 2. CRecordset類:代表從數(shù)據源選擇的一組記錄。CRecordset 類允許指定要運行的SQL查詢,它將運行

7、查詢并維護自數(shù)據庫返回的記錄集。可以修改和更新記錄,還可增加、刪除記錄,并將所做的變動反饋到該數(shù)據庫中。 3. CRecordView類:提供了一個表單視圖與某個記錄集直接相連,利用對話框數(shù)據交換(DDX)機制在記錄集與表單視圖的控件之間傳輸數(shù)據。 4. CFieldExchange類:支持記錄字段數(shù)據交換(DFX),即記錄集字段數(shù)據成員與相應的數(shù)據庫的標的字段之間的數(shù)據交換。 5. CDBException類:代表ODBC 類產生的異常。,12.2 使用ODBC創(chuàng)建數(shù)據庫應用程序,本節(jié)將創(chuàng)建一個支持ODBC 數(shù)據庫的SDI 應用程序。該應用程序可以編輯、更新、添加和刪除ODBC 數(shù)據庫中的記

8、錄記錄,并允許用戶檢索記錄,以及對記錄進行排序和查找。,12.2.1 連接數(shù)據庫,在運行訪問數(shù)據庫的前臺軟件之前,要在控制面板上的ODBC數(shù)據源控制臺中注冊一下,為了方便起見,假定使用Access數(shù)據庫,則可以通過以下步驟訪問Access數(shù)據庫。 1. 建立ODBC數(shù)據源 打開【控制面板】【管理工具】【數(shù)據源(ODBC)】,如圖12.2所示。選擇“系統(tǒng)DSN”選項卡,然后單擊“添加”按鈕,則彈出“創(chuàng)建新數(shù)據源”對話框,如圖12.3所示,接著選擇“Microsoft Access Driver(*.mdb)”就可以了。,連接數(shù)據庫(Con),2. 連接數(shù)據源 在選擇了“Microsoft Acc

9、ess Driver(*.mdb)”并單擊“完成”按鈕后,將彈出“ODBC Microsoft Access 安裝”對話框,如圖12.4所示。需要為該數(shù)據源起一個簡短的名稱,應用程序將使用該名稱來指定用于數(shù)據庫連接的ODBC數(shù)據源配置,對于本例,給該數(shù)據源命名為student。然后將事先創(chuàng)建的用戶數(shù)據源添加到ODBC數(shù)據源管理器的用戶數(shù)據源列表中,以供在之后程序中使用,如圖12.5所示。,12.2.2 建立應用程序,在本章的示例應用程序中,需要創(chuàng)建一個支持數(shù)據庫的標準SDI 風格的應用程序。其過程如下: 1. 用MFC AppWizard(exe)創(chuàng)建一個SDI 應用程序,工程名為DBOper

10、ation。 2. 在AppWizard第2步的對話框中,有兩個選擇項來支持數(shù)據庫的訪問,每種選擇都會產生一個CRecordView類的派生類和一個文檔類,文檔類又分為沒有文件支持的文檔和有文件支持的文檔,如圖12.6所示。,建立應用程序(Con),3. 繼續(xù)AppWizard的工作,保留各步默認設置。 4. 設計用來查看和編輯數(shù)據庫記錄的主窗體,如圖12.9所示。 5. 顯示數(shù)據。要在窗體上顯示表中各字段的內容,只要在CDBOperationView: DoDataExchange函數(shù)中添加代碼就可以了。,12.2.3 實現(xiàn)數(shù)據庫基本操作,前面已經創(chuàng)建了一個數(shù)據庫應用程序。但是,它還缺少某些

11、對數(shù)據庫中記錄進行操作的基本功能,比如記錄的添加、刪除、修改、排序和查詢等操作。接下來,分別介紹這些功能的實現(xiàn)。 1. 添加記錄 為了能夠在程序界面中實現(xiàn)添加、修改記錄的功能,首先需要在CDBOperationView類中為6個EditBox控件添加相應的變量。這樣,在控件中的所有改動都會在第一時間反映在各個與控件相關的變量中。 添加記錄的步驟是:首先使用成員函數(shù)AddNew進入添加記錄的模式,接著填寫新記錄的各個字段,然后使用Update函數(shù)實現(xiàn)真正的添加。,實現(xiàn)數(shù)據庫基本操作(Con),2. 刪除記錄 刪除記錄的步驟是:首先移動到需要刪除的記錄上,然后使用Delete函數(shù)就能刪除該記錄。記

12、錄一經刪除,還應調用MoveNext 函數(shù)將指針移動到記錄集的下一條記錄。 為了實現(xiàn)刪除記錄的功能,需要在【記錄】菜單中添加1個標題為“刪除”,ID為ID_RECORD_DELETE的菜單項。然后,為刪除記錄的消息映射函數(shù)中添加代碼。,實現(xiàn)數(shù)據庫基本操作(Con),3. 更改記錄 更改記錄的步驟是:首先使用成員函數(shù)Edit進入更改記錄的模式,接著修改當前的記錄,然后使用Update函數(shù)實現(xiàn)真正的更改。 為了實現(xiàn)更改記錄的功能,需要在【記錄】菜單中添加1個標題為“更改”,ID為ID_RECORD_UPDATE的菜單項。然后,為更改記錄的消息映射函數(shù)中添加代碼。,實現(xiàn)數(shù)據庫基本操作(Con),4.

13、 對記錄排序 排序可以通過SQL語句的ORDER BY實現(xiàn),在CRecordset類中有1個數(shù)據成員m_strSort,它封裝了ORDER BY的功能,可以通過該成員的設置來實現(xiàn)排序。 為了實現(xiàn)排序功能,需要在【記錄】菜單添加1個新的菜單項【排序】,該菜單為彈出式菜單,其下面由2個標題為“按編號”和“按年齡”,ID分別為ID_RECORD_SORTNO和ID_RECORD_SORTAGE的子菜單項構成,用于按編號和年齡進行升序排列。,實現(xiàn)數(shù)據庫基本操作(Con),5. 查詢記錄 查找可以通過SQL 語句的select語句實現(xiàn),在CRecordset 類中有1個數(shù)據成員m_strFilter,其

14、封裝了select語句的功能,可以通過該成員的設置來實現(xiàn)查找。,12.3 使用ADO創(chuàng)建數(shù)據庫應用程序,ADO是Microsoft 的數(shù)據庫應用程序開發(fā)的接口,是建立在OLE DB 之上的高級數(shù)據庫訪問技術。ADO訪問數(shù)據庫是通過訪問OLE DB數(shù)據提供程序來進行的,提供了一種對OLE DB數(shù)據提供程序的簡單高層訪問接口。ADO技術簡化了OLE DB的操作,因為OLE DB的程序中使用了大量的COM接口,而ADO封裝了這些接口。所以,ADO是一種高層的訪問技術。,12.3.1 ADO 對象模型,ADO 對象模型提供了7 種對象,分別是連接對象Connection、命令對象Command、記錄集

15、對象Recordset、參數(shù)對象Parameter、字段對象Field、錯誤對象Error和屬性對象Property,其中前3個對象是ADO中最重要的。,12.3.2使用ADO對象創(chuàng)建數(shù)據庫應用程序,用 ADO 開發(fā)數(shù)據庫應用程序,有兩種方法。 一種是使用ADO Data控件,這種方法簡單,用戶只需編寫相對較少的代碼,甚至不寫一行代碼,就可以實現(xiàn)對數(shù)據庫的訪問。其缺點是效率比較低,用戶對程序的控制比較弱,不能充分發(fā)揮ADO 的強大功能。 另一種是直接使用ADO 對象,這種方法可以非常靈活地控制程序的細節(jié),而且效率、性能很高,可以充分發(fā)揮ADO 的特性。,使用ADO對象進行程序設計的方法,1. 生成應用程序框架并初始化OLE/COM庫環(huán)境 2. 引入ADO庫文件 3. 定義對象指針 4. 創(chuàng)建數(shù)據庫連接 5. 打開記錄集 6. 瀏覽記錄集 7. 添加記錄 8. 刪除記錄 9. 更改記錄 10. 還原COM 環(huán)境以及關閉連接對象和記錄集對象,12.3.3 ADO控件簡介,1. ADO Data 控件 通過ADO Data 控件可以從數(shù)據庫中獲取數(shù)

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論