2023年全國(guó)碩士研究生考試考研英語(yǔ)一試題真題(含答案詳解+作文范文)_第1頁(yè)
已閱讀1頁(yè),還剩38頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

1、第 15 章應(yīng)用開(kāi)發(fā)——數(shù)據(jù)庫(kù)通用類的設(shè)計(jì),由于系統(tǒng)中對(duì)于數(shù)據(jù)庫(kù)操作都需要處理連接字符串、創(chuàng)建連接、執(zhí)行查詢、更新等通用操作,為了提高代碼的復(fù)用性,在軟件開(kāi)發(fā)時(shí)一般都創(chuàng)建數(shù)據(jù)庫(kù)通用類完成數(shù)據(jù)庫(kù)的通用操作。本章介紹了流行的三層體系架構(gòu)的概念、利用LINQ to SQL自動(dòng)創(chuàng)建數(shù)據(jù)庫(kù)通用類的方法和利用數(shù)據(jù)庫(kù)通用類操作數(shù)據(jù)庫(kù)的簡(jiǎn)單例子。,,系統(tǒng)分析 數(shù)據(jù)庫(kù)分析和設(shè)計(jì) 系統(tǒng)設(shè)計(jì) 運(yùn)行系統(tǒng) 在我的WinForm應(yīng)用中應(yīng)用本系統(tǒng) 開(kāi)發(fā)過(guò)

2、程常見(jiàn)問(wèn)題及解決,,系統(tǒng)分析 數(shù)據(jù)庫(kù)分析和設(shè)計(jì) 系統(tǒng)設(shè)計(jì) 運(yùn)行系統(tǒng) 在我的WinForm應(yīng)用中應(yīng)用本系統(tǒng) 開(kāi)發(fā)過(guò)程常見(jiàn)問(wèn)題及解決,15.1 系統(tǒng)分析,使用ADO.NET訪問(wèn)數(shù)據(jù)庫(kù)時(shí),每次操作都要設(shè)置數(shù)據(jù)庫(kù)連接connection屬性、建立連接、使用SQLcommand和進(jìn)行事務(wù)處理等,比較繁瑣且有很多重復(fù)操作。項(xiàng)目開(kāi)發(fā)中一般創(chuàng)建數(shù)據(jù)庫(kù)通用類把這些繁瑣的、常用的操作封裝起來(lái),以更方便、安全地使用ADO.NET。,15.1.1

3、 三層體系結(jié)構(gòu),目前,流行的項(xiàng)目多采用三層體系結(jié)構(gòu)。三層體系結(jié)構(gòu)就是在表示層(界面層)與數(shù)數(shù)據(jù)訪問(wèn)層之間加入一個(gè)中間層,叫做業(yè)務(wù)邏輯層,一般將業(yè)務(wù)規(guī)則、數(shù)據(jù)訪問(wèn)、合法性校驗(yàn)等工作放到中間層進(jìn)行處理。通常情況下,客戶端不直接與數(shù)據(jù)庫(kù)進(jìn)行交互,而是通過(guò)中間層與數(shù)據(jù)庫(kù)進(jìn)行交互。,,典型的三層結(jié)構(gòu)包括表示層、業(yè)務(wù)邏輯層和數(shù)據(jù)訪問(wèn)層,使用三層結(jié)構(gòu)創(chuàng)建的應(yīng)用系統(tǒng),由于層與層之間的低耦合和層內(nèi)部的高內(nèi)聚,使得解決方案的維護(hù)變得更容易。表示層:主要是

4、指與用戶交互的界面,用于顯示數(shù)據(jù)和接收用戶的輸入,將用戶輸入的數(shù)據(jù)傳遞給業(yè)務(wù)邏輯層,一般不包含任何實(shí)際的業(yè)務(wù)處理,當(dāng)業(yè)務(wù)邏輯層的數(shù)據(jù)發(fā)生變化時(shí),表示層就會(huì)顯示出更新的結(jié)果。表示層是應(yīng)用程序提供給用戶的操作界面,通常是包含Windows窗體或Web頁(yè)面的Windows窗體應(yīng)用程序或Web應(yīng)用程序。業(yè)務(wù)邏輯層:是表示層和數(shù)據(jù)訪問(wèn)層之間的橋梁,它代表應(yīng)用程序的核心功能,負(fù)責(zé)處理數(shù)據(jù)層的數(shù)據(jù),實(shí)現(xiàn)具體的業(yè)務(wù)邏輯。業(yè)務(wù)邏輯層通常為類庫(kù)。,,數(shù)據(jù)

5、訪問(wèn)層:主要實(shí)現(xiàn)對(duì)數(shù)據(jù)的操作,將數(shù)據(jù)庫(kù)中的數(shù)據(jù)提交給業(yè)務(wù)層,同時(shí)將業(yè)務(wù)層處理過(guò)的數(shù)據(jù)保存到數(shù)據(jù)庫(kù)中。數(shù)據(jù)訪問(wèn)層可以訪問(wèn)關(guān)系數(shù)據(jù)庫(kù)、文本文件或者XML文件,數(shù)據(jù)訪問(wèn)層通常為類庫(kù)。使用三層結(jié)構(gòu)的目的是是使項(xiàng)目結(jié)構(gòu)更清楚,分工更明確,有利于維護(hù)。三層架構(gòu)就像員工、經(jīng)理和董事長(zhǎng)之間的關(guān)系一樣,員工向經(jīng)理匯報(bào)工作,經(jīng)理匯總后再向董事長(zhǎng)匯報(bào),反之,董事長(zhǎng)有什么命令傳達(dá)給經(jīng)理即可,再由經(jīng)理通知每位員工。如果員工都直接找董事長(zhǎng),管理就會(huì)變得比較混亂。

6、,,三層架構(gòu)搭建好之后,有一個(gè)問(wèn)題需要解決,如何在三層之間傳遞數(shù)據(jù)呢?目前通用的解決方法有兩種:一種是創(chuàng)建實(shí)體層使用實(shí)體層中的實(shí)體類在三層之間傳遞數(shù)據(jù),另一種是使用數(shù)據(jù)集在三層之間傳遞數(shù)據(jù)。使用實(shí)體類的優(yōu)點(diǎn)是實(shí)體類是一個(gè)比較容易控制的對(duì)象,它具有面向?qū)ο蟮幕咎卣鳎梢宰杂傻南驅(qū)嶓w類中添加行為等;實(shí)體類消除了關(guān)系數(shù)據(jù)和對(duì)象之間的差異,便于操縱關(guān)系數(shù)據(jù);能更好地發(fā)揮分層的作用,更好地進(jìn)行復(fù)用和擴(kuò)展,增強(qiáng)靈活性。,15.1.2 系統(tǒng)分析,

7、系統(tǒng)分析是開(kāi)發(fā)應(yīng)用系統(tǒng)的關(guān)鍵,通過(guò)系統(tǒng)分析了解客戶需要什么樣的程序,系統(tǒng)需要完成什么功能。通過(guò)軟件需求規(guī)格說(shuō)明書(shū)描述系統(tǒng)的總體要求,并且作為各方面溝通的依據(jù),也為下一步工作提供基準(zhǔn)。系統(tǒng)開(kāi)發(fā)人員要按照軟件需求規(guī)格說(shuō)明書(shū)完成相應(yīng)的功能。本節(jié)介紹的“數(shù)據(jù)庫(kù)通用類”的設(shè)計(jì)來(lái)源于第24章的“人力資源管理系統(tǒng)”,重點(diǎn)介紹如何利用LINQ to SQL建立負(fù)責(zé)數(shù)據(jù)庫(kù)操作的通用實(shí)體類。 “人力資源管理系統(tǒng)”中的主要功能,如員工管理、考評(píng)管理、員工調(diào)

8、動(dòng)管理、培訓(xùn)管理、獎(jiǎng)懲管理等都需要操作數(shù)據(jù)庫(kù),每次操作需要設(shè)置連接屬性、建立連接、使用SQLcommand、事務(wù)處理等,非常麻煩并有很多重復(fù)工作,所以創(chuàng)建一個(gè)通用類,以更方便、安全地操作數(shù)據(jù)庫(kù)。,,“人力資源管理系統(tǒng)”采用三層架構(gòu)模型。利用LINQ to SQL創(chuàng)建數(shù)據(jù)庫(kù)通用實(shí)體類實(shí)現(xiàn)在三個(gè)模塊之間使用對(duì)象進(jìn)行數(shù)據(jù)傳遞和負(fù)責(zé)操作數(shù)據(jù)庫(kù)。利用.NET Framework 3.5中新增的LINQ可以簡(jiǎn)化三層體系架構(gòu)的搭建,在以往的系統(tǒng)中,數(shù)

9、據(jù)訪問(wèn)層要訪問(wèn)數(shù)據(jù)字段,業(yè)務(wù)邏輯層要得到數(shù)據(jù)都需要通過(guò)數(shù)據(jù)訪問(wèn)層來(lái)實(shí)現(xiàn),通常創(chuàng)建數(shù)據(jù)庫(kù)通用類來(lái)輔助數(shù)據(jù)訪問(wèn)層操作數(shù)據(jù)庫(kù),數(shù)據(jù)庫(kù)通用類可以看做單獨(dú)的一層(數(shù)據(jù)模型層),LINQ可以自動(dòng)生成數(shù)據(jù)模型層,產(chǎn)生一個(gè)dbml(Database Mark Language數(shù)據(jù)庫(kù)描述語(yǔ)言)文件用來(lái)描述數(shù)據(jù)庫(kù)信息,dbml文件是xml格式的文檔,有了它可以快速生成實(shí)體類,實(shí)體類作為實(shí)體層負(fù)責(zé)對(duì)數(shù)據(jù)庫(kù)操作。如下圖的DataLinq層就是實(shí)體層和數(shù)據(jù)模型層

10、的組合。利用LINQ創(chuàng)建的三層體系結(jié)構(gòu)如下圖所示。,,,,系統(tǒng)分析 數(shù)據(jù)庫(kù)分析和設(shè)計(jì) 系統(tǒng)設(shè)計(jì) 運(yùn)行系統(tǒng) 在我的WinForm應(yīng)用中應(yīng)用本系統(tǒng) 開(kāi)發(fā)過(guò)程常見(jiàn)問(wèn)題及解決,15.2 數(shù)據(jù)庫(kù)分析和設(shè)計(jì),數(shù)據(jù)庫(kù)設(shè)計(jì)是系統(tǒng)建設(shè)中非常重要的環(huán)節(jié),合理有效的數(shù)據(jù)庫(kù)設(shè)計(jì)對(duì)系統(tǒng)的性能至關(guān)重要,也是創(chuàng)建系統(tǒng)的基礎(chǔ)。,15.2.1 數(shù)據(jù)庫(kù)分析和設(shè)計(jì),通過(guò)系統(tǒng)分析,“人力資源管理系統(tǒng)”數(shù)據(jù)庫(kù)中包含如下多個(gè)表。在SQL Server 2008 或者

11、SQL Server 2005中創(chuàng)建數(shù)據(jù)庫(kù)HrManage和系統(tǒng)中用到的表。表和表結(jié)構(gòu)如下。1. 考勤表(Attendance),用于存放員工考勤的信息。,,2. 獎(jiǎng)懲表(RewardsInfo),用于記錄員工的考獎(jiǎng)懲信息。,,3. 員工培訓(xùn)表(TrainInfo):記錄員工的培訓(xùn)信息。,,4.員工調(diào)動(dòng)表(EmpTransfer),用于記錄員工的調(diào)動(dòng)信息。,5. 員工信息表(EmployInfo),,6. 職位表(PostInfo),

12、7. 部門(mén)表(Section),8. 工資變動(dòng)表(TransferWage),15.2.2 數(shù)據(jù)庫(kù)通用類的創(chuàng)建,本節(jié)利用LINQ to SQL創(chuàng)建一個(gè)DataLinq層來(lái)組織數(shù)據(jù)庫(kù)通用類,DataLinq層包含一個(gè)DataContext類和若干實(shí)體類,其結(jié)構(gòu)如下:,,DataContext類 :項(xiàng)目中的每一個(gè) LINQ to SQL設(shè)計(jì)器將自動(dòng)創(chuàng)建一個(gè) DataContext類,用來(lái)查詢數(shù)據(jù)庫(kù)、檢索數(shù)據(jù)記錄和更新數(shù)據(jù)庫(kù)操作的主要類,它

13、包含了每一個(gè)表的屬性。實(shí)體類 :LINQ to SQL為添加到設(shè)計(jì)器(.dbml文件)中的每一個(gè)表創(chuàng)建對(duì)應(yīng)的實(shí)體類,這些實(shí)體類包含了強(qiáng)類型屬性集合,映射到數(shù)據(jù)庫(kù)中對(duì)應(yīng)表的字段。LINQ to SQL使用這些實(shí)體類來(lái)生成數(shù)據(jù)操作的SQL腳本,同時(shí),也可以創(chuàng)建實(shí)體類的實(shí)例,給實(shí)例賦值,然后在不同的層之間作為數(shù)據(jù)傳輸對(duì)象進(jìn)行傳遞。,,DataContext類中的實(shí)體類和屬性直接映射到對(duì)應(yīng)數(shù)據(jù)表和字段。缺省情況下,在DataContext類中

14、,LINQ 使用繼承抽象類 MappingSource 的 AttributedMappingSource 類來(lái)存放表和字段的映射信息,從數(shù)據(jù)庫(kù)中檢索記錄和提交數(shù)據(jù)更新到數(shù)據(jù)庫(kù)時(shí)需要這些映射信息。,利用Visual Studio 2008創(chuàng)建數(shù)據(jù)庫(kù)通用類的步驟如下。,? 啟動(dòng)Visual Studio 2008,新建一個(gè)“類庫(kù)”項(xiàng)目,名稱為“DataLinq”。? 單擊菜單【項(xiàng)目】?【添加類】,選擇【Linq to SQL類】,輸入類

15、的名稱 “HrDataLinq”。單擊【添加】按鈕后,系統(tǒng)將增加HrDataLinq類到項(xiàng)目中,并自動(dòng)創(chuàng)建一個(gè)空白的設(shè)計(jì)器(.dbml文件),同時(shí)附有【服務(wù)器資源管理器】的鏈接,也創(chuàng)建相關(guān)的dbml.layout文件(XML文件)和designer.cs文件(DataContext類文件)。? 打開(kāi)【服務(wù)器資源管理器】,并建立到HrManage數(shù)據(jù)庫(kù)的鏈接,然后導(dǎo)航到HrManage數(shù)據(jù)庫(kù),將數(shù)據(jù)庫(kù)中的表拖放到設(shè)計(jì)器。最后,保存文件后

16、就自動(dòng)生成了包含相關(guān)的屬性、方法的DataContext類和實(shí)體類。,,? 單擊【生成】-【生成解決方案】,數(shù)據(jù)庫(kù)通用類和實(shí)體類就可以使用了。自動(dòng)生成的數(shù)據(jù)庫(kù)通用類DataContext(類名是HrDataLinqDataContext)類圖如下:,,系統(tǒng)分析 數(shù)據(jù)庫(kù)分析和設(shè)計(jì) 系統(tǒng)設(shè)計(jì) 運(yùn)行系統(tǒng) 在我的WinForm應(yīng)用中應(yīng)用本系統(tǒng) 開(kāi)發(fā)過(guò)程常見(jiàn)問(wèn)題及解決,15.3 系統(tǒng)設(shè)計(jì),自動(dòng)生成的數(shù)據(jù)庫(kù)通用類DataContext

17、中的實(shí)體類和屬性直接映射到對(duì)應(yīng)數(shù)據(jù)表和字段。缺省情況下,在DataContext類中,LINQ 使用繼承抽象類 MappingSource 的 AttributedMappingSource 類來(lái)存放表和字段的映射信息,從數(shù)據(jù)庫(kù)中檢索記錄和提交數(shù)據(jù)更新到數(shù)據(jù)庫(kù)時(shí)需要這些映射信息。部分代碼如下(代碼15-1.txt)。,,系統(tǒng)分析 數(shù)據(jù)庫(kù)分析和設(shè)計(jì) 系統(tǒng)設(shè)計(jì) 運(yùn)行系統(tǒng) 在我的WinForm應(yīng)用中應(yīng)用本系統(tǒng) 開(kāi)發(fā)過(guò)程常見(jiàn)問(wèn)題及解決

18、,15.4 運(yùn)行系統(tǒng),為了使用數(shù)據(jù)庫(kù)通用類,下面我們開(kāi)發(fā)一個(gè)查詢職位信息的三層結(jié)構(gòu)的例子。系統(tǒng)體系結(jié)構(gòu)設(shè)計(jì)如下:1. DataLinq層DataLinq層是15.3節(jié)中設(shè)計(jì)的數(shù)據(jù)庫(kù)通用類。2. 添加數(shù)據(jù)訪問(wèn)層在解決方案中添加類庫(kù)項(xiàng)目HrDAL,添加對(duì)DataLinq層的引用,編寫(xiě)代碼如下:3. 創(chuàng)建業(yè)務(wù)邏輯層在解決方案中添加類庫(kù)項(xiàng)目HrBLL,添加對(duì)DataLinq層和HrDAL層的引用,編寫(xiě)代碼如下:,4. 添加表

19、示層,創(chuàng)建Windows窗體應(yīng)用程序,項(xiàng)目名為“HrManage”,在Form顯示PostInfo表中的記錄,窗體上放置一個(gè)Label和DataGridView控件;分別添加對(duì)DataLinq層和HrBLL層的引用,界面如下:編寫(xiě)代碼如下(代碼15-4.txt)。將Windows窗體應(yīng)用程序設(shè)置為啟動(dòng)項(xiàng)目后運(yùn)行,運(yùn)行界面如下。,,系統(tǒng)分析 數(shù)據(jù)庫(kù)分析和設(shè)計(jì) 系統(tǒng)設(shè)計(jì) 運(yùn)行系統(tǒng) 在我的WinForm應(yīng)用中應(yīng)用本系統(tǒng) 開(kāi)

20、發(fā)過(guò)程常見(jiàn)問(wèn)題及解決,15.5 在我的Windows窗體應(yīng)用程序中應(yīng)用本系統(tǒng),15.2節(jié)中創(chuàng)建的數(shù)據(jù)庫(kù)通用類將用在整個(gè)“人力資源管理系統(tǒng)”項(xiàng)目中,作為DataLinq層,負(fù)責(zé)操作數(shù)據(jù)庫(kù),從本章的介紹可以看到利用Linq to SQL創(chuàng)建一個(gè)DataContext類,不需要設(shè)置connection屬性、建立connection,也不需要使用SQL語(yǔ)句就能操作數(shù)據(jù)庫(kù),非常簡(jiǎn)單和方便,極大的提高了開(kāi)發(fā)效率,降低了開(kāi)發(fā)難度。,,系統(tǒng)分析 數(shù)

21、據(jù)庫(kù)分析和設(shè)計(jì) 系統(tǒng)設(shè)計(jì) 運(yùn)行系統(tǒng) 在我的WinForm應(yīng)用中應(yīng)用本系統(tǒng) 開(kāi)發(fā)過(guò)程常見(jiàn)問(wèn)題及解決,15.6 開(kāi)發(fā)過(guò)程常見(jiàn)問(wèn)題及解決,開(kāi)發(fā)過(guò)程中經(jīng)常出現(xiàn)的問(wèn)題和解決方案如下.1. 出現(xiàn)“error:40--無(wú)法打開(kāi)到SQL Server的連接”錯(cuò)誤。,,解決方法如下:? 可能是連接字符串有錯(cuò)。如是Windows窗體應(yīng)用程序在app.config或settings.settings改正為正確的代碼,注意連接字符串中Data S

22、ource后面是服務(wù)器的名稱,一般寫(xiě)成“計(jì)算機(jī)名\數(shù)據(jù)庫(kù)實(shí)例名”格式,也可以寫(xiě)成“.”,.代表當(dāng)前服務(wù)器,或?qū)懗蒷ocal,或?qū)懗伞?27.0.0.1”等。如是Web應(yīng)用程序,在web.config中更改連接字符串。如:connectionString="Data Source=CS\SQLEXPRESS;Initial Catalog=HrManage;Integrated Security=True",?

23、如字符串正確,可能是沒(méi)有啟用數(shù)據(jù)庫(kù)的遠(yuǎn)程連接。啟動(dòng)遠(yuǎn)程連接:打開(kāi) SQL Server 2008 或2005的外圍應(yīng)用配置器,單擊 開(kāi)始->所有程序->Ms SQL Server->配置工具-> SQL Server外圍應(yīng)用配置器->服務(wù)和連接的外圍應(yīng)用配置器->打開(kāi)MSSQLSERVER節(jié)點(diǎn)下的Database Engine 節(jié)點(diǎn),先擇"遠(yuǎn)程連接",接下建議選擇"同時(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ù)僅提供信息存儲(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)論