




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(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ù)庫(kù)編程,本節(jié)主要內(nèi)容,數(shù)據(jù)庫(kù)的訪問(wèn)和ODBC 使用ODBC創(chuàng)建數(shù)據(jù)庫(kù)應(yīng)用程序 使用ADO創(chuàng)建數(shù)據(jù)庫(kù)應(yīng)用程序,12.1 數(shù)據(jù)庫(kù)的訪問(wèn)和ODBC,在使用Visual C+進(jìn)行數(shù)據(jù)庫(kù)編程之前,先簡(jiǎn)單介紹一些概念。,12.1.1 數(shù)據(jù)庫(kù)、數(shù)據(jù)庫(kù)模型和數(shù)據(jù)庫(kù)管理系統(tǒng),數(shù)據(jù)庫(kù) 數(shù)據(jù)庫(kù)是依照某種數(shù)據(jù)模型組織起來(lái)并存放二級(jí)存儲(chǔ)器中的數(shù)據(jù)集合。 數(shù)據(jù)庫(kù)具有如下特點(diǎn):盡可能不重復(fù),以最優(yōu)方式為某個(gè)特定組織的多種應(yīng)用服務(wù),其數(shù)據(jù)結(jié)構(gòu)獨(dú)立于使用它的應(yīng)用程序,對(duì)數(shù)據(jù)的增、刪、改和檢索由統(tǒng)一軟件進(jìn)行管理和控制。,數(shù)據(jù)庫(kù)模型,現(xiàn)行的數(shù)據(jù)庫(kù)模型主要有以下四種: 層次結(jié)構(gòu)模型 層次結(jié)構(gòu)模型
2、實(shí)質(zhì)上是一種有根結(jié)點(diǎn)的定向有序樹(shù)。按照層次模型建立的數(shù)據(jù)庫(kù)系統(tǒng)稱為層次模型數(shù)據(jù)庫(kù)系統(tǒng)。 網(wǎng)狀結(jié)構(gòu)模型 按照網(wǎng)狀數(shù)據(jù)結(jié)構(gòu)建立的數(shù)據(jù)庫(kù)系統(tǒng)稱為網(wǎng)狀數(shù)據(jù)庫(kù)系統(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ù)庫(kù)系統(tǒng)被稱為關(guān)系數(shù)據(jù)庫(kù)系統(tǒng)。 面向?qū)ο竽P?隨著信息技術(shù)和市場(chǎng)的發(fā)展,對(duì)數(shù)據(jù)處理技術(shù)也提出了更高要求,為了能夠處理復(fù)雜對(duì)象數(shù)據(jù)就產(chǎn)生了面向?qū)ο髷?shù)據(jù)模型。面向?qū)ο髷?shù)據(jù)庫(kù)是面向?qū)ο蟾拍詈蛿?shù)據(jù)庫(kù)技術(shù)相結(jié)合產(chǎn)物。,數(shù)據(jù)庫(kù)管理系統(tǒng),數(shù)據(jù)庫(kù)管理系統(tǒng)(DBMS)為用戶提供對(duì)數(shù)據(jù)庫(kù)操作的各種命令、工具
3、及方法,包括數(shù)據(jù)庫(kù)的建立以及記錄的輸入、修改、檢索、顯示、刪除和統(tǒng)計(jì)等。 常用的數(shù)據(jù)庫(kù)系統(tǒng)有Access、mySQL、Sybase、SQL Server和Oracle等。這些DBMS 都提供了一個(gè)SQL 接口。,12.1.2 開(kāi)放式數(shù)據(jù)庫(kù)接口ODBC,ODBC(Open Database Connectivity,開(kāi)放數(shù)據(jù)庫(kù)互連)是微軟公司開(kāi)放服務(wù)結(jié)構(gòu)(WOSA,Windows Open Services Architecture)中有關(guān)數(shù)據(jù)庫(kù)的一個(gè)組成部分,它建立了一組規(guī)范,并提供了一組對(duì)數(shù)據(jù)庫(kù)訪問(wèn)的標(biāo)準(zhǔn)API(應(yīng)用程序編程接口)。這些API利用SQL來(lái)完成其大部分任務(wù)。ODBC本身也提供了
4、對(duì)SQL語(yǔ)言的支持,用戶可以直接將SQL語(yǔ)句送給ODBC。,開(kāi)放式數(shù)據(jù)庫(kù)接口ODBC(Con),一個(gè)基于ODBC的應(yīng)用程序?qū)?shù)據(jù)庫(kù)的操作不依賴任何DBMS,不直接與DBMS打交道,所有的數(shù)據(jù)庫(kù)操作由對(duì)應(yīng)的DBMS的ODBC驅(qū)動(dòng)程序完成。由此可見(jiàn),ODBC的最大優(yōu)點(diǎn)是能以統(tǒng)一的方式處理所有的數(shù)據(jù)庫(kù)。,開(kāi)放式數(shù)據(jù)庫(kù)接口ODBC(Con),一個(gè)完整的ODBC由下列幾個(gè)部件組成: 1. 應(yīng)用程序(Application)。 2. ODBC管理器(Administrator):主要任務(wù)是管理安裝的ODBC驅(qū)動(dòng)程序和管理數(shù)據(jù)源。 3. 驅(qū)動(dòng)程序管理器(Driver Manager):對(duì)用戶是透明的。任務(wù)是
5、管理ODBC驅(qū)動(dòng)程序,是ODBC中最重要的部件。 4. ODBC API:包含在動(dòng)態(tài)庫(kù)中的一個(gè)函數(shù)集合、一個(gè)錯(cuò)誤代碼集合、一個(gè)標(biāo)準(zhǔn)的SQL語(yǔ)句集合,用來(lái)調(diào)用DBMS中的數(shù)據(jù)。 5. ODBC 驅(qū)動(dòng)程序(Database drivers):是一些DLL,提供了ODBC和數(shù)據(jù)庫(kù)之間的接口。 6. 數(shù)據(jù)源:數(shù)據(jù)源包含了數(shù)據(jù)庫(kù)位置和數(shù)據(jù)庫(kù)類型等信息,實(shí)際上是一種數(shù)據(jù)連接的抽象。,開(kāi)放式數(shù)據(jù)庫(kù)接口ODBC(Con),應(yīng)用程序要訪問(wèn)一個(gè)數(shù)據(jù)庫(kù),首先必須用ODBC管理器注冊(cè)一個(gè)數(shù)據(jù)源,管理器根據(jù)數(shù)據(jù)源提供的數(shù)據(jù)庫(kù)位置、數(shù)據(jù)庫(kù)類型及ODBC驅(qū)動(dòng)程序等信息,建立起ODBC與具體數(shù)據(jù)庫(kù)的聯(lián)系。這樣,只要應(yīng)用程序?qū)?/p>
6、數(shù)據(jù)源名提供給ODBC,ODBC就能建立起與相應(yīng)數(shù)據(jù)庫(kù)的連接。 在ODBC中,ODBC API不能直接訪問(wèn)數(shù)據(jù)庫(kù),必須通過(guò)驅(qū)動(dòng)程序管理器與數(shù)據(jù)庫(kù)交換信息。,12.1.3 MFC ODBC 技術(shù),MFC的ODBC類對(duì)較復(fù)雜的ODBC API進(jìn)行了封裝,提供了簡(jiǎn)化的調(diào)用接口,從而大大方便了數(shù)據(jù)庫(kù)應(yīng)用程序的開(kāi)發(fā)。,MFC ODBC 技術(shù)(Con),MFC 的ODBC 類主要包括如下5 類。 1. CDatabase類:主要功能是建立與數(shù)據(jù)源的連接,可以在整個(gè)應(yīng)用程序中共享這些信息。 2. CRecordset類:代表從數(shù)據(jù)源選擇的一組記錄。CRecordset 類允許指定要運(yùn)行的SQL查詢,它將運(yùn)行
7、查詢并維護(hù)自數(shù)據(jù)庫(kù)返回的記錄集。可以修改和更新記錄,還可增加、刪除記錄,并將所做的變動(dòng)反饋到該數(shù)據(jù)庫(kù)中。 3. CRecordView類:提供了一個(gè)表單視圖與某個(gè)記錄集直接相連,利用對(duì)話框數(shù)據(jù)交換(DDX)機(jī)制在記錄集與表單視圖的控件之間傳輸數(shù)據(jù)。 4. CFieldExchange類:支持記錄字段數(shù)據(jù)交換(DFX),即記錄集字段數(shù)據(jù)成員與相應(yīng)的數(shù)據(jù)庫(kù)的標(biāo)的字段之間的數(shù)據(jù)交換。 5. CDBException類:代表ODBC 類產(chǎn)生的異常。,12.2 使用ODBC創(chuàng)建數(shù)據(jù)庫(kù)應(yīng)用程序,本節(jié)將創(chuàng)建一個(gè)支持ODBC 數(shù)據(jù)庫(kù)的SDI 應(yīng)用程序。該應(yīng)用程序可以編輯、更新、添加和刪除ODBC 數(shù)據(jù)庫(kù)中的記
8、錄記錄,并允許用戶檢索記錄,以及對(duì)記錄進(jìn)行排序和查找。,12.2.1 連接數(shù)據(jù)庫(kù),在運(yùn)行訪問(wèn)數(shù)據(jù)庫(kù)的前臺(tái)軟件之前,要在控制面板上的ODBC數(shù)據(jù)源控制臺(tái)中注冊(cè)一下,為了方便起見(jiàn),假定使用Access數(shù)據(jù)庫(kù),則可以通過(guò)以下步驟訪問(wèn)Access數(shù)據(jù)庫(kù)。 1. 建立ODBC數(shù)據(jù)源 打開(kāi)【控制面板】【管理工具】【數(shù)據(jù)源(ODBC)】,如圖12.2所示。選擇“系統(tǒng)DSN”選項(xiàng)卡,然后單擊“添加”按鈕,則彈出“創(chuàng)建新數(shù)據(jù)源”對(duì)話框,如圖12.3所示,接著選擇“Microsoft Access Driver(*.mdb)”就可以了。,連接數(shù)據(jù)庫(kù)(Con),2. 連接數(shù)據(jù)源 在選擇了“Microsoft Acc
9、ess Driver(*.mdb)”并單擊“完成”按鈕后,將彈出“ODBC Microsoft Access 安裝”對(duì)話框,如圖12.4所示。需要為該數(shù)據(jù)源起一個(gè)簡(jiǎn)短的名稱,應(yīng)用程序?qū)⑹褂迷撁Q來(lái)指定用于數(shù)據(jù)庫(kù)連接的ODBC數(shù)據(jù)源配置,對(duì)于本例,給該數(shù)據(jù)源命名為student。然后將事先創(chuàng)建的用戶數(shù)據(jù)源添加到ODBC數(shù)據(jù)源管理器的用戶數(shù)據(jù)源列表中,以供在之后程序中使用,如圖12.5所示。,12.2.2 建立應(yīng)用程序,在本章的示例應(yīng)用程序中,需要?jiǎng)?chuàng)建一個(gè)支持?jǐn)?shù)據(jù)庫(kù)的標(biāo)準(zhǔn)SDI 風(fēng)格的應(yīng)用程序。其過(guò)程如下: 1. 用MFC AppWizard(exe)創(chuàng)建一個(gè)SDI 應(yīng)用程序,工程名為DBOper
10、ation。 2. 在AppWizard第2步的對(duì)話框中,有兩個(gè)選擇項(xiàng)來(lái)支持?jǐn)?shù)據(jù)庫(kù)的訪問(wèn),每種選擇都會(huì)產(chǎn)生一個(gè)CRecordView類的派生類和一個(gè)文檔類,文檔類又分為沒(méi)有文件支持的文檔和有文件支持的文檔,如圖12.6所示。,建立應(yīng)用程序(Con),3. 繼續(xù)AppWizard的工作,保留各步默認(rèn)設(shè)置。 4. 設(shè)計(jì)用來(lái)查看和編輯數(shù)據(jù)庫(kù)記錄的主窗體,如圖12.9所示。 5. 顯示數(shù)據(jù)。要在窗體上顯示表中各字段的內(nèi)容,只要在CDBOperationView: DoDataExchange函數(shù)中添加代碼就可以了。,12.2.3 實(shí)現(xiàn)數(shù)據(jù)庫(kù)基本操作,前面已經(jīng)創(chuàng)建了一個(gè)數(shù)據(jù)庫(kù)應(yīng)用程序。但是,它還缺少某些
11、對(duì)數(shù)據(jù)庫(kù)中記錄進(jìn)行操作的基本功能,比如記錄的添加、刪除、修改、排序和查詢等操作。接下來(lái),分別介紹這些功能的實(shí)現(xiàn)。 1. 添加記錄 為了能夠在程序界面中實(shí)現(xiàn)添加、修改記錄的功能,首先需要在CDBOperationView類中為6個(gè)EditBox控件添加相應(yīng)的變量。這樣,在控件中的所有改動(dòng)都會(huì)在第一時(shí)間反映在各個(gè)與控件相關(guān)的變量中。 添加記錄的步驟是:首先使用成員函數(shù)AddNew進(jìn)入添加記錄的模式,接著填寫(xiě)新記錄的各個(gè)字段,然后使用Update函數(shù)實(shí)現(xiàn)真正的添加。,實(shí)現(xiàn)數(shù)據(jù)庫(kù)基本操作(Con),2. 刪除記錄 刪除記錄的步驟是:首先移動(dòng)到需要?jiǎng)h除的記錄上,然后使用Delete函數(shù)就能刪除該記錄。記
12、錄一經(jīng)刪除,還應(yīng)調(diào)用MoveNext 函數(shù)將指針移動(dòng)到記錄集的下一條記錄。 為了實(shí)現(xiàn)刪除記錄的功能,需要在【記錄】菜單中添加1個(gè)標(biāo)題為“刪除”,ID為ID_RECORD_DELETE的菜單項(xiàng)。然后,為刪除記錄的消息映射函數(shù)中添加代碼。,實(shí)現(xiàn)數(shù)據(jù)庫(kù)基本操作(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ù)中添加代碼。,實(shí)現(xiàn)數(shù)據(jù)庫(kù)基本操作(Con),4.
13、 對(duì)記錄排序 排序可以通過(guò)SQL語(yǔ)句的ORDER BY實(shí)現(xiàn),在CRecordset類中有1個(gè)數(shù)據(jù)成員m_strSort,它封裝了ORDER BY的功能,可以通過(guò)該成員的設(shè)置來(lái)實(shí)現(xiàn)排序。 為了實(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)行升序排列。,實(shí)現(xiàn)數(shù)據(jù)庫(kù)基本操作(Con),5. 查詢記錄 查找可以通過(guò)SQL 語(yǔ)句的select語(yǔ)句實(shí)現(xiàn),在CRecordset 類中有1個(gè)數(shù)據(jù)成員m_strFilter,其
14、封裝了select語(yǔ)句的功能,可以通過(guò)該成員的設(shè)置來(lái)實(shí)現(xiàn)查找。,12.3 使用ADO創(chuàng)建數(shù)據(jù)庫(kù)應(yīng)用程序,ADO是Microsoft 的數(shù)據(jù)庫(kù)應(yīng)用程序開(kāi)發(fā)的接口,是建立在OLE DB 之上的高級(jí)數(shù)據(jù)庫(kù)訪問(wèn)技術(shù)。ADO訪問(wèn)數(shù)據(jù)庫(kù)是通過(guò)訪問(wèn)OLE DB數(shù)據(jù)提供程序來(lái)進(jìn)行的,提供了一種對(duì)OLE DB數(shù)據(jù)提供程序的簡(jiǎn)單高層訪問(wèn)接口。ADO技術(shù)簡(jiǎn)化了OLE DB的操作,因?yàn)镺LE DB的程序中使用了大量的COM接口,而ADO封裝了這些接口。所以,ADO是一種高層的訪問(wèn)技術(shù)。,12.3.1 ADO 對(duì)象模型,ADO 對(duì)象模型提供了7 種對(duì)象,分別是連接對(duì)象Connection、命令對(duì)象Command、記錄集
15、對(duì)象Recordset、參數(shù)對(duì)象Parameter、字段對(duì)象Field、錯(cuò)誤對(duì)象Error和屬性對(duì)象Property,其中前3個(gè)對(duì)象是ADO中最重要的。,12.3.2使用ADO對(duì)象創(chuàng)建數(shù)據(jù)庫(kù)應(yīng)用程序,用 ADO 開(kāi)發(fā)數(shù)據(jù)庫(kù)應(yīng)用程序,有兩種方法。 一種是使用ADO Data控件,這種方法簡(jiǎn)單,用戶只需編寫(xiě)相對(duì)較少的代碼,甚至不寫(xiě)一行代碼,就可以實(shí)現(xiàn)對(duì)數(shù)據(jù)庫(kù)的訪問(wèn)。其缺點(diǎn)是效率比較低,用戶對(duì)程序的控制比較弱,不能充分發(fā)揮ADO 的強(qiáng)大功能。 另一種是直接使用ADO 對(duì)象,這種方法可以非常靈活地控制程序的細(xì)節(jié),而且效率、性能很高,可以充分發(fā)揮ADO 的特性。,使用ADO對(duì)象進(jìn)行程序設(shè)計(jì)的方法,1. 生成應(yīng)用程序框架并初始化OLE/COM庫(kù)環(huán)境 2. 引入ADO庫(kù)文件 3. 定義對(duì)象指針 4. 創(chuàng)建數(shù)據(jù)庫(kù)連接 5. 打開(kāi)記錄集 6. 瀏覽記錄集 7. 添加記錄 8. 刪除記錄 9. 更改記錄 10. 還原COM 環(huán)境以及關(guān)閉連接對(duì)象和記錄集對(duì)象,12.3.3 ADO控件簡(jiǎn)介,1. ADO Data 控件 通過(guò)ADO Data 控件可以從數(shù)據(jù)庫(kù)中獲取數(shù)
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 河道保潔長(zhǎng)效管理辦法
- 河南綠化養(yǎng)護(hù)管理辦法
- 行業(yè)行為管理與運(yùn)營(yíng)優(yōu)化
- 來(lái)華工作經(jīng)費(fèi)管理辦法
- 水文自動(dòng)測(cè)報(bào)系統(tǒng)的運(yùn)行機(jī)制與質(zhì)量評(píng)價(jià)標(biāo)準(zhǔn)研究
- 杭州法院薪酬管理辦法
- 前臺(tái)考勤考核管理辦法
- 保健按摩養(yǎng)生管理辦法
- 水土保持生態(tài)產(chǎn)品價(jià)值轉(zhuǎn)化機(jī)制研究
- 企業(yè)安全生產(chǎn)費(fèi)用計(jì)提標(biāo)準(zhǔn)
- 2023年高考真題-物理(廣東卷) 含答案
- 2025年湖北荊門(mén)市交通旅游投資集團(tuán)有限公司招聘筆試參考題庫(kù)附帶答案詳解
- 無(wú)損檢測(cè)員(鐵路探傷工)理論試題(高級(jí)工)
- 2025-2030年中國(guó)無(wú)水叔丁醇產(chǎn)業(yè)發(fā)展現(xiàn)狀及前景趨勢(shì)分析報(bào)告
- DB37T4252-2020靈芝菌種質(zhì)量要求
- 《學(xué)前教育法》知識(shí)考試題庫(kù)100題(含答案)
- 2025年工業(yè)和信息化部人才交流中心第二次招聘1人管理單位筆試遴選500模擬題附帶答案詳解
- 寧夏回族自治區(qū)城市體檢工作技術(shù)指南(試行)2024
- 國(guó)開(kāi)《課堂提問(wèn)與引導(dǎo)》期末大作業(yè)及答案
- 固定式啟閉機(jī)及閘門(mén)的檢修與維護(hù)規(guī)范
- 內(nèi)蒙古呼和浩特市(2024年-2025年小學(xué)五年級(jí)語(yǔ)文)統(tǒng)編版期末考試(下學(xué)期)試卷及答案
評(píng)論
0/150
提交評(píng)論