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

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

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

2、PPT,數(shù)據(jù)庫模型,現(xiàn)行的數(shù)據(jù)庫模型主要有以下四種: 層次結(jié)構(gòu)模型 層次結(jié)構(gòu)模型實(shí)質(zhì)上是一種有根結(jié)點(diǎn)的定向有序樹。按照層次模型建立的數(shù)據(jù)庫系統(tǒng)稱為層次模型數(shù)據(jù)庫系統(tǒng)。 網(wǎng)狀結(jié)構(gòu)模型 按照網(wǎng)狀數(shù)據(jù)結(jié)構(gòu)建立的數(shù)據(jù)庫系統(tǒng)稱為網(wǎng)狀數(shù)據(jù)庫系統(tǒng),用數(shù)學(xué)方法可將網(wǎng)狀數(shù)據(jù)結(jié)構(gòu)轉(zhuǎn)化為層次數(shù)據(jù)結(jié)構(gòu)。 關(guān)系結(jié)構(gòu)模型 關(guān)系式數(shù)據(jù)結(jié)構(gòu)把一些復(fù)雜的數(shù)據(jù)結(jié)構(gòu)歸結(jié)為簡(jiǎn)單的二元關(guān)系(即二維表格形式)。由關(guān)系數(shù)據(jù)結(jié)構(gòu)組成的數(shù)據(jù)庫系統(tǒng)被稱為關(guān)系數(shù)據(jù)庫系統(tǒng)。 面向?qū)ο竽P?隨著信息技術(shù)和市場(chǎng)的發(fā)展,對(duì)數(shù)據(jù)處理技術(shù)也提出了更高要求,為了能夠處理復(fù)雜對(duì)象數(shù)據(jù)就產(chǎn)生了面向?qū)ο髷?shù)據(jù)模型。面向?qū)ο髷?shù)據(jù)庫是面向?qū)ο蟾拍詈蛿?shù)據(jù)庫技術(shù)相結(jié)合產(chǎn)物。,

3、5,學(xué)習(xí)交流PPT,數(shù)據(jù)庫管理系統(tǒng),數(shù)據(jù)庫管理系統(tǒng)(DBMS)為用戶提供對(duì)數(shù)據(jù)庫操作的各種命令、工具及方法,包括數(shù)據(jù)庫的建立以及記錄的輸入、修改、檢索、顯示、刪除和統(tǒng)計(jì)等。 常用的數(shù)據(jù)庫系統(tǒng)有Access、mySQL、Sybase、SQL Server和Oracle等。這些DBMS 都提供了一個(gè)SQL 接口。,6,學(xué)習(xí)交流PPT,12.1.2 開放式數(shù)據(jù)庫接口ODBC,ODBC(Open Database Connectivity,開放數(shù)據(jù)庫互連)是微軟公司開放服務(wù)結(jié)構(gòu)(WOSA,Windows Open Services Architecture)中有關(guān)數(shù)據(jù)庫的一個(gè)組成部分,它建立了一組規(guī)范

4、,并提供了一組對(duì)數(shù)據(jù)庫訪問的標(biāo)準(zhǔn)API(應(yīng)用程序編程接口)。這些API利用SQL來完成其大部分任務(wù)。ODBC本身也提供了對(duì)SQL語言的支持,用戶可以直接將SQL語句送給ODBC。,7,學(xué)習(xí)交流PPT,開放式數(shù)據(jù)庫接口ODBC(Con),一個(gè)基于ODBC的應(yīng)用程序?qū)?shù)據(jù)庫的操作不依賴任何DBMS,不直接與DBMS打交道,所有的數(shù)據(jù)庫操作由對(duì)應(yīng)的DBMS的ODBC驅(qū)動(dòng)程序完成。由此可見,ODBC的最大優(yōu)點(diǎn)是能以統(tǒng)一的方式處理所有的數(shù)據(jù)庫。,8,學(xué)習(xí)交流PPT,開放式數(shù)據(jù)庫接口ODBC(Con),一個(gè)完整的ODBC由下列幾個(gè)部件組成: 1. 應(yīng)用程序(Application)。 2. ODBC管理器

5、(Administrator):主要任務(wù)是管理安裝的ODBC驅(qū)動(dòng)程序和管理數(shù)據(jù)源。 3. 驅(qū)動(dòng)程序管理器(Driver Manager):對(duì)用戶是透明的。任務(wù)是管理ODBC驅(qū)動(dòng)程序,是ODBC中最重要的部件。 4. ODBC API:包含在動(dòng)態(tài)庫中的一個(gè)函數(shù)集合、一個(gè)錯(cuò)誤代碼集合、一個(gè)標(biāo)準(zhǔn)的SQL語句集合,用來調(diào)用DBMS中的數(shù)據(jù)。 5. ODBC 驅(qū)動(dòng)程序(Database drivers):是一些DLL,提供了ODBC和數(shù)據(jù)庫之間的接口。 6. 數(shù)據(jù)源:數(shù)據(jù)源包含了數(shù)據(jù)庫位置和數(shù)據(jù)庫類型等信息,實(shí)際上是一種數(shù)據(jù)連接的抽象。,9,學(xué)習(xí)交流PPT,開放式數(shù)據(jù)庫接口ODBC(Con),應(yīng)用程序要

6、訪問一個(gè)數(shù)據(jù)庫,首先必須用ODBC管理器注冊(cè)一個(gè)數(shù)據(jù)源,管理器根據(jù)數(shù)據(jù)源提供的數(shù)據(jù)庫位置、數(shù)據(jù)庫類型及ODBC驅(qū)動(dòng)程序等信息,建立起ODBC與具體數(shù)據(jù)庫的聯(lián)系。這樣,只要應(yīng)用程序?qū)?shù)據(jù)源名提供給ODBC,ODBC就能建立起與相應(yīng)數(shù)據(jù)庫的連接。 在ODBC中,ODBC API不能直接訪問數(shù)據(jù)庫,必須通過驅(qū)動(dòng)程序管理器與數(shù)據(jù)庫交換信息。,10,學(xué)習(xí)交流PPT,12.1.3 MFC ODBC 技術(shù),MFC的ODBC類對(duì)較復(fù)雜的ODBC API進(jìn)行了封裝,提供了簡(jiǎn)化的調(diào)用接口,從而大大方便了數(shù)據(jù)庫應(yīng)用程序的開發(fā)。,11,學(xué)習(xí)交流PPT,MFC ODBC 技術(shù)(Con),MFC 的ODBC 類主要包括如

7、下5 類。 1. CDatabase類:主要功能是建立與數(shù)據(jù)源的連接,可以在整個(gè)應(yīng)用程序中共享這些信息。 2. CRecordset類:代表從數(shù)據(jù)源選擇的一組記錄。CRecordset 類允許指定要運(yùn)行的SQL查詢,它將運(yùn)行查詢并維護(hù)自數(shù)據(jù)庫返回的記錄集??梢孕薷暮透掠涗洠€可增加、刪除記錄,并將所做的變動(dòng)反饋到該數(shù)據(jù)庫中。 3. CRecordView類:提供了一個(gè)表單視圖與某個(gè)記錄集直接相連,利用對(duì)話框數(shù)據(jù)交換(DDX)機(jī)制在記錄集與表單視圖的控件之間傳輸數(shù)據(jù)。 4. CFieldExchange類:支持記錄字段數(shù)據(jù)交換(DFX),即記錄集字段數(shù)據(jù)成員與相應(yīng)的數(shù)據(jù)庫的標(biāo)的字段之間的數(shù)據(jù)交

8、換。 5. CDBException類:代表ODBC 類產(chǎn)生的異常。,12,學(xué)習(xí)交流PPT,12.2 使用ODBC創(chuàng)建數(shù)據(jù)庫應(yīng)用程序,本節(jié)將創(chuàng)建一個(gè)支持ODBC 數(shù)據(jù)庫的SDI 應(yīng)用程序。該應(yīng)用程序可以編輯、更新、添加和刪除ODBC 數(shù)據(jù)庫中的記錄記錄,并允許用戶檢索記錄,以及對(duì)記錄進(jìn)行排序和查找。,13,學(xué)習(xí)交流PPT,12.2.1 連接數(shù)據(jù)庫,在運(yùn)行訪問數(shù)據(jù)庫的前臺(tái)軟件之前,要在控制面板上的ODBC數(shù)據(jù)源控制臺(tái)中注冊(cè)一下,為了方便起見,假定使用Access數(shù)據(jù)庫,則可以通過以下步驟訪問Access數(shù)據(jù)庫。 1. 建立ODBC數(shù)據(jù)源 打開【控制面板】【管理工具】【數(shù)據(jù)源(ODBC)】,如圖1

9、2.2所示。選擇“系統(tǒng)DSN”選項(xiàng)卡,然后單擊“添加”按鈕,則彈出“創(chuàng)建新數(shù)據(jù)源”對(duì)話框,如圖12.3所示,接著選擇“Microsoft Access Driver(*.mdb)”就可以了。,14,學(xué)習(xí)交流PPT,連接數(shù)據(jù)庫(Con),2. 連接數(shù)據(jù)源 在選擇了“Microsoft Access Driver(*.mdb)”并單擊“完成”按鈕后,將彈出“ODBC Microsoft Access 安裝”對(duì)話框,如圖12.4所示。需要為該數(shù)據(jù)源起一個(gè)簡(jiǎn)短的名稱,應(yīng)用程序?qū)⑹褂迷撁Q來指定用于數(shù)據(jù)庫連接的ODBC數(shù)據(jù)源配置,對(duì)于本例,給該數(shù)據(jù)源命名為student。然后將事先創(chuàng)建的用戶數(shù)據(jù)源添加到

10、ODBC數(shù)據(jù)源管理器的用戶數(shù)據(jù)源列表中,以供在之后程序中使用,如圖12.5所示。,15,學(xué)習(xí)交流PPT,12.2.2 建立應(yīng)用程序,在本章的示例應(yīng)用程序中,需要?jiǎng)?chuàng)建一個(gè)支持?jǐn)?shù)據(jù)庫的標(biāo)準(zhǔn)SDI 風(fēng)格的應(yīng)用程序。其過程如下: 1. 用MFC AppWizard(exe)創(chuàng)建一個(gè)SDI 應(yīng)用程序,工程名為DBOperation。 2. 在AppWizard第2步的對(duì)話框中,有兩個(gè)選擇項(xiàng)來支持?jǐn)?shù)據(jù)庫的訪問,每種選擇都會(huì)產(chǎn)生一個(gè)CRecordView類的派生類和一個(gè)文檔類,文檔類又分為沒有文件支持的文檔和有文件支持的文檔,如圖12.6所示。,16,學(xué)習(xí)交流PPT,建立應(yīng)用程序(Con),3. 繼續(xù)App

11、Wizard的工作,保留各步默認(rèn)設(shè)置。 4. 設(shè)計(jì)用來查看和編輯數(shù)據(jù)庫記錄的主窗體,如圖12.9所示。 5. 顯示數(shù)據(jù)。要在窗體上顯示表中各字段的內(nèi)容,只要在CDBOperationView: DoDataExchange函數(shù)中添加代碼就可以了。,17,學(xué)習(xí)交流PPT,12.2.3 實(shí)現(xiàn)數(shù)據(jù)庫基本操作,前面已經(jīng)創(chuàng)建了一個(gè)數(shù)據(jù)庫應(yīng)用程序。但是,它還缺少某些對(duì)數(shù)據(jù)庫中記錄進(jìn)行操作的基本功能,比如記錄的添加、刪除、修改、排序和查詢等操作。接下來,分別介紹這些功能的實(shí)現(xiàn)。 1. 添加記錄 為了能夠在程序界面中實(shí)現(xiàn)添加、修改記錄的功能,首先需要在CDBOperationView類中為6個(gè)EditBox控

12、件添加相應(yīng)的變量。這樣,在控件中的所有改動(dòng)都會(huì)在第一時(shí)間反映在各個(gè)與控件相關(guān)的變量中。 添加記錄的步驟是:首先使用成員函數(shù)AddNew進(jìn)入添加記錄的模式,接著填寫新記錄的各個(gè)字段,然后使用Update函數(shù)實(shí)現(xiàn)真正的添加。,18,學(xué)習(xí)交流PPT,實(shí)現(xiàn)數(shù)據(jù)庫基本操作(Con),2. 刪除記錄 刪除記錄的步驟是:首先移動(dòng)到需要?jiǎng)h除的記錄上,然后使用Delete函數(shù)就能刪除該記錄。記錄一經(jīng)刪除,還應(yīng)調(diào)用MoveNext 函數(shù)將指針移動(dòng)到記錄集的下一條記錄。 為了實(shí)現(xiàn)刪除記錄的功能,需要在【記錄】菜單中添加1個(gè)標(biāo)題為“刪除”,ID為ID_RECORD_DELETE的菜單項(xiàng)。然后,為刪除記錄的消息映射函數(shù)

13、中添加代碼。,19,學(xué)習(xí)交流PPT,實(shí)現(xiàn)數(shù)據(jù)庫基本操作(Con),3. 更改記錄 更改記錄的步驟是:首先使用成員函數(shù)Edit進(jìn)入更改記錄的模式,接著修改當(dāng)前的記錄,然后使用Update函數(shù)實(shí)現(xiàn)真正的更改。 為了實(shí)現(xiàn)更改記錄的功能,需要在【記錄】菜單中添加1個(gè)標(biāo)題為“更改”,ID為ID_RECORD_UPDATE的菜單項(xiàng)。然后,為更改記錄的消息映射函數(shù)中添加代碼。,20,學(xué)習(xí)交流PPT,實(shí)現(xiàn)數(shù)據(jù)庫基本操作(Con),4. 對(duì)記錄排序 排序可以通過SQL語句的ORDER BY實(shí)現(xiàn),在CRecordset類中有1個(gè)數(shù)據(jù)成員m_strSort,它封裝了ORDER BY的功能,可以通過該成員的設(shè)置來實(shí)現(xiàn)

14、排序。 為了實(shí)現(xiàn)排序功能,需要在【記錄】菜單添加1個(gè)新的菜單項(xiàng)【排序】,該菜單為彈出式菜單,其下面由2個(gè)標(biāo)題為“按編號(hào)”和“按年齡”,ID分別為ID_RECORD_SORTNO和ID_RECORD_SORTAGE的子菜單項(xiàng)構(gòu)成,用于按編號(hào)和年齡進(jìn)行升序排列。,21,學(xué)習(xí)交流PPT,實(shí)現(xiàn)數(shù)據(jù)庫基本操作(Con),5. 查詢記錄 查找可以通過SQL 語句的select語句實(shí)現(xiàn),在CRecordset 類中有1個(gè)數(shù)據(jù)成員m_strFilter,其封裝了select語句的功能,可以通過該成員的設(shè)置來實(shí)現(xiàn)查找。,22,學(xué)習(xí)交流PPT,12.3 使用ADO創(chuàng)建數(shù)據(jù)庫應(yīng)用程序,ADO是Microsoft 的

15、數(shù)據(jù)庫應(yīng)用程序開發(fā)的接口,是建立在OLE DB 之上的高級(jí)數(shù)據(jù)庫訪問技術(shù)。ADO訪問數(shù)據(jù)庫是通過訪問OLE DB數(shù)據(jù)提供程序來進(jìn)行的,提供了一種對(duì)OLE DB數(shù)據(jù)提供程序的簡(jiǎn)單高層訪問接口。ADO技術(shù)簡(jiǎn)化了OLE DB的操作,因?yàn)镺LE DB的程序中使用了大量的COM接口,而ADO封裝了這些接口。所以,ADO是一種高層的訪問技術(shù)。,23,學(xué)習(xí)交流PPT,12.3.1 ADO 對(duì)象模型,ADO 對(duì)象模型提供了7 種對(duì)象,分別是連接對(duì)象Connection、命令對(duì)象Command、記錄集對(duì)象Recordset、參數(shù)對(duì)象Parameter、字段對(duì)象Field、錯(cuò)誤對(duì)象Error和屬性對(duì)象Proper

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

溫馨提示

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

最新文檔

評(píng)論

0/150

提交評(píng)論