圖書管理系統(tǒng)畢業(yè)設(shè)計論文_第1頁
已閱讀1頁,還剩68頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p><b>  摘 要</b></p><p>  隨著各圖書館的圖書數(shù)量不斷增多和圖書館規(guī)模的不斷擴大,管理這些龐大的體系非常困難的,因為圖書的情況是隨時改變的,因此必需對圖書進行動態(tài)的管理,而這對于一個管理人員來說是一件比較復雜的事情。</p><p>  本文介紹了管理信息系統(tǒng)的基本設(shè)計方法,詳細闡述了整個應(yīng)用系統(tǒng)的設(shè)計思路,并對各部分設(shè)計周期進行

2、了詳盡的分析,最終達成了一個完整的設(shè)計方案;本文的系統(tǒng)是一個圖書管理系統(tǒng),包括管理員界面和密碼登錄界面然后進入主菜單,主菜單包括了圖書管理,讀者管理,圖書借閱管理等幾個大的模塊。該系統(tǒng)為單機版,相應(yīng)的硬件設(shè)備也分為單機型的方案。適用于各個圖書管理的信息管理。系統(tǒng)基于好用、易用、美觀的原則為用戶定制了一套統(tǒng)一的人機界面。系統(tǒng)各模塊按功能主要分為兩大類:編輯類完成以編輯為主的功能,如增加、刪除、修改等;瀏覽類完成以再現(xiàn)為主的功能,如查詢、瀏

3、覽等。</p><p>  關(guān)鍵詞:Visual Studio 2005;圖書管理系統(tǒng);數(shù)據(jù)庫</p><p><b>  Abstract</b></p><p>  Increases unceasingly along with various libraries' books' quantity with the lib

4、rary scale unceasing expansion, manages these huge systems to be difficult, because the books situation is momentarily changes, must therefore to the books carry on the dynamic management, but this regarding an administr

5、ative personnel is a quite complex matter.</p><p>  This article introduced management information system's basic design method, elaborated in detail the entire application system's design mentality,

6、 and has carried on the exhaustive analysis to various part of design cycle, achieved a complete design proposal finally; This article system is a books management system management system, then entered the main menu inc

7、luding the manager contact surface and the password debarkation contact surface, the main menu includes the books management, the rea</p><p>  Keywords:Visual Studio 2005,Books management system management s

8、ystem,database</p><p><b>  目 錄</b></p><p><b>  摘 要1</b></p><p>  第1章 緒 論5</p><p>  1.1畢業(yè)設(shè)計主要內(nèi)容、功能及技術(shù)指標5</p><p>  1.2目前圖書管理系統(tǒng)存

9、在的問題5</p><p><b>  1.3課題意義6</b></p><p>  1.4論文的工作和安排6</p><p>  第2章 可行性分析8</p><p>  2.1 問題描述8</p><p>  2.2可行性分析研究9</p><p>  2

10、.2.1操作可行性9</p><p>  2.2.2 技術(shù)可行性10</p><p>  2.2.3 經(jīng)濟可行性10</p><p>  2.3結(jié)論意見10</p><p>  第3章 系統(tǒng)總體設(shè)計11</p><p>  3.1系統(tǒng)設(shè)計思想11</p><p>  3.2系統(tǒng)功能模

11、塊圖12</p><p>  3.3系統(tǒng)流程圖13</p><p>  3.4 程序流程圖14</p><p>  3.5功能模塊設(shè)計18</p><p>  3.6 程序接口描述18</p><p>  3.6.1 外部接口18</p><p>  3.6.2 內(nèi)部接口18<

12、;/p><p>  3.7 數(shù)據(jù)庫的設(shè)計18</p><p>  3.7.1 系統(tǒng)設(shè)計局部ER模式19</p><p>  3.7.2.系統(tǒng)設(shè)計全局ER模式21</p><p>  3.7.3數(shù)據(jù)庫邏輯設(shè)計22</p><p>  3.8系統(tǒng)主要數(shù)據(jù)字典24</p><p>  第4章

13、 程序設(shè)計與編碼25</p><p>  4.1數(shù)據(jù)庫連接25</p><p>  4.2系統(tǒng)管理設(shè)計26</p><p>  4.3圖書管理設(shè)計30</p><p>  4.4查詢管理設(shè)計39</p><p>  4.5 用戶管理設(shè)計43</p><p>  4.6 讀者管理設(shè)計

14、46</p><p>  4.7借還管理設(shè)計54</p><p>  第5章 軟件測試62</p><p>  5.1 軟件測試的方法與步驟62</p><p>  5.2 測試用例運行過程及測試結(jié)果分析63</p><p>  5.2.1模塊測試63</p><p>  5.2.2集

15、成測試64</p><p>  5.2.3 驗收測試65</p><p><b>  第6章 總結(jié)66</b></p><p><b>  參考文獻67</b></p><p><b>  致 謝68</b></p><p>  第1章 緒

16、 論</p><p>  1.1畢業(yè)設(shè)計主要內(nèi)容、功能及技術(shù)指標</p><p>  圖書館管理系統(tǒng)的總體目標是:在計算機網(wǎng)絡(luò),數(shù)據(jù)庫和先進的開發(fā)平臺上,利用現(xiàn)有的軟件,配置一定的硬件,分析和設(shè)計一個具有開放體系結(jié)構(gòu)的、易擴充的、易維護的、具有良好人機交互界面的圖書館管理系統(tǒng),為決策者和管理者提供充足的信息、快捷的查詢和有效的管理方式,減少不必要的損失和浪費,提高圖書館管理的效率。&l

17、t;/p><p>  1. 根據(jù)可行性研究的結(jié)果和客戶的要求,分析現(xiàn)有情況及問題,采用C/S或B/S結(jié)構(gòu),將圖書館管理系統(tǒng)劃分為:新書訂購管理、圖書管理、讀者管理、借閱管理、信息查詢等;</p><p>  2. 整個系統(tǒng)可以選擇采用2層C/S結(jié)構(gòu)或3層B/S結(jié)構(gòu)。數(shù)據(jù)庫系統(tǒng)可采用Access, SQL Server 2005等,前臺開發(fā)工具可以選用PowerBuilder或Visual St

18、udio、ASP或JSP等;</p><p>  3. 圖書館管理系統(tǒng)所涉及的信息有圖書、讀者、借閱、圖書管理員等方面,可通過系統(tǒng)流程圖、業(yè)務(wù)流程圖、數(shù)據(jù)流程圖和數(shù)據(jù)字典對其進行描述,在分析和設(shè)計的基礎(chǔ)上,提出系統(tǒng)的總體框架并進行詳細設(shè)計,為系統(tǒng)實現(xiàn)做準備。</p><p>  1.2目前圖書管理系統(tǒng)存在的問題</p><p>  1)檢索速度慢、效率低</p

19、><p>  因為圖書館的藏書種類多、數(shù)量多,將藏書準確地分門別類,快速檢索,手工進行非常困難往往是終于查到了二偉的信息,館中沒有此書或已被別人借走。圖書館的規(guī)模越大,這個問題越突出。</p><p>  2)借書、還書工作量大</p><p>  借書、還書頻率越大,說明圖書館的作用越大,然而隨之而來的大量的借書、還書登記、實存圖書的更新以及借出圖書超期、遺失等的處理

20、,其工作量之大,往往是人工操作所難以勝任的。而且經(jīng)常會出現(xiàn)這樣那樣的差錯。</p><p>  3)圖書統(tǒng)計工作難、藏書更新不能及時完成。</p><p>  圖書館的圖書應(yīng)根據(jù)科學技術(shù)的發(fā)展和教學工作的需要及時添加和更新,然而由于藏書數(shù)量及圖書種類越來越多,加上自然損耗,人為破壞,使圖書的統(tǒng)計工作難以及時完成,藏書的更新也就很難有針對性地進行,藏書的知識結(jié)構(gòu)得不到良好地控制。</p

21、><p>  我校也是一所發(fā)展中的高校,近兒年的發(fā)展速度很快,圖書館的規(guī)模和藏書數(shù)量也不斷的擴大,為了解決海量圖書的管理問題,改變傳統(tǒng)的管理方式也是迫在眉睫了。</p><p><b>  1.3課題意義</b></p><p>  隨著計算機的廣泛應(yīng)用,其逐步成為現(xiàn)代化的標志。圖書館或者一些企業(yè)內(nèi)部,甚至是書店,在正常運行過程中總是面對大量的讀者

22、信息,書籍信息以及兩者相互作用產(chǎn)生的借書信息、還書信息。因此需要對讀者資源、書籍資源、借書信息、還書信息進行管理,及時了解各個環(huán)節(jié)中信息的變更,要對因此而產(chǎn)生的單據(jù)進行及時的處理,為了提高圖書館或者企業(yè)內(nèi)部對圖書存銷的自動化的管理,能夠更快速的滿足讀者的要求,提高各種工作的效率,現(xiàn)對其設(shè)計相應(yīng)的系統(tǒng),以達到上述的目的。</p><p>  圖書管理系統(tǒng)的主要功能是實現(xiàn)圖書館圖書借閱和歸還的管理的自動化。圍繞這一主

23、要功能,本系統(tǒng)涉及到以下核心功能:借閱管理,歸還管理。除了這些核心功能外,還包括一些基本和輔助功能,它們是:用戶管理、圖書管理、統(tǒng)計查詢。</p><p>  1.4論文的工作和安排</p><p>  本次設(shè)計的目標是,開發(fā)一個圖書館借閱管理系統(tǒng)。借助該系統(tǒng),管理員通過快捷可靠的數(shù)據(jù)庫管理,方便的管理圖書館的信息資料,規(guī)范化的管理讀者用戶,設(shè)定不同用戶權(quán)限,方便讀者的使用,最終達到提高圖

24、書館資源利用效率的目的。</p><p>  論文設(shè)計和實現(xiàn)了圖書借閱管理系統(tǒng)系統(tǒng),可以根據(jù)用戶的不同權(quán)限,對圖書館的的各種信息進行添加、刪除、修改或查詢操作。論文分為六個部分:</p><p>  第一章即本章緒論,簡述圖書館借閱管理系統(tǒng)這個課題的背景情況以及開發(fā)本系統(tǒng)的意義。</p><p>  第二章為可行性分析,本章中明確了系統(tǒng)需要實現(xiàn)的功能,分析了系統(tǒng)的可

25、行性,并介紹根據(jù)系統(tǒng)的需求選擇的開發(fā)工具和技術(shù)的概況。</p><p>  第三章是總體設(shè)計,詳細描述了本系統(tǒng)中數(shù)據(jù)庫的設(shè)計情況,并給出了系統(tǒng)總體界面的設(shè)計方案。 </p><p>  第四章為程序設(shè)計與編碼各主要功能模塊的實現(xiàn)方法和部分關(guān)鍵代碼,同時提供了個主要界面運行的參考圖片,以更直觀了解系統(tǒng)的實現(xiàn)情況。</p><p>  第五章是軟件測試,測試系統(tǒng)功能實現(xiàn)

26、并對測試結(jié)果進行記錄分析</p><p>  第六章為總結(jié),為此次畢業(yè)設(shè)計做一個總結(jié),總結(jié)所獲得的經(jīng)驗和體會。</p><p>  第2章 可行性分析</p><p><b>  2.1 問題描述</b></p><p>  圖書管理系統(tǒng)是典型的信息管理系統(tǒng)(MIS),其開發(fā)主要包括后臺數(shù)據(jù)庫的建立和維護以及前臺應(yīng)用程

27、序的開發(fā)兩個方面,一方面要求建立起數(shù)據(jù)一致性和完整性強、數(shù)據(jù)安全性好的數(shù)據(jù)庫;另一方面則要求應(yīng)用程序具有功能完備,已使用等特點。</p><p>  原來的圖書管理處理中心進行信息管理主要是基于手工處理,信息處理工作量大,容易出錯,缺乏系統(tǒng)、規(guī)范的信息管理手段?,F(xiàn)在準備建立的圖書管理系統(tǒng),要對圖書館的圖書管理、讀者管理、圖書借閱管理等日常管理工作實行計算機統(tǒng)一管理,以提高工作效率和管理水平。</p>

28、<p>  圖書館作為提供學習的場所,不僅要求便于管理,而且要求給讀者和借閱者提供方便快速的查找、借閱和登記手續(xù)。</p><p>  圖書館需要統(tǒng)一圖書管理,對各類書籍的借閱情況和圖書館現(xiàn)有藏書的數(shù)量、種類要及時掌握,這就要求它具有很強的時效性。既要減少舊書和大量內(nèi)容重復的圖書占用有限空間而又要盡量做到圖書種類的齊全,作為圖書館的管理人員需要及時地對圖書進行上架和注銷處理。</p>&

29、lt;p>  圖書管理涉及圖書信息、系統(tǒng)用戶信息、讀者信息、圖書借閱者信息等多種數(shù)據(jù)管理。從管理的角度可將數(shù)據(jù)管理分為3類:圖書信息管理、系統(tǒng)用戶管理、圖書管理系統(tǒng)是典型的信息管理系統(tǒng)(MIS),其開發(fā)主要包括后臺數(shù)據(jù)庫的建立和維護以及前臺應(yīng)用程序的開發(fā)兩個方面,一方面要求建立起數(shù)據(jù)一致性和完整性強、數(shù)據(jù)安全性好的數(shù)據(jù)庫;另一方面則要求應(yīng)用程序具有功能完備,已使用等特點。</p><p>  原來的圖書管理

30、處理中心進行信息管理主要是基于手工處理,信息處理工作量大,容易出錯,缺乏系統(tǒng)、規(guī)范的信息管理手段?,F(xiàn)在準備建立的圖書管理系統(tǒng),要對圖書館的圖書管理、讀者管理、圖書借閱管理等日常管理工作實行計算機統(tǒng)一管理,以提高工作效率和管理水平。</p><p>  圖書館作為提供學習的場所,不僅要求便于管理,而且要求給讀者和借閱者提供方便快速的查找、借閱和登記手續(xù)。</p><p>  圖書館需要統(tǒng)一圖

31、書管理,對各類書籍的借閱情況和圖書館現(xiàn)有藏書的數(shù)量、種類要及時掌握,這就要求它具有很強的時效性。既要減少舊書和大量內(nèi)容重復的圖書占用有限空間而又要盡量做到圖書種類的齊全,作為圖書館的管理人員需要及時地對圖書進行上架和注銷處理。</p><p>  圖書管理涉及圖書信息、系統(tǒng)用戶信息、讀者信息、圖書借閱者信息等多種數(shù)據(jù)管理。從管理的角度可將數(shù)據(jù)管理分為3類:圖書信息管理、系統(tǒng)用戶管理、讀者數(shù)據(jù)管理。圖書信息管理包括

32、圖書征訂、借還、查詢等操作,系統(tǒng)用戶管理包括用戶類別和用戶數(shù)量管理,讀者數(shù)據(jù)管理包括讀者類別管理和個人數(shù)據(jù)的錄入、修改和刪除。</p><p>  讀者數(shù)據(jù)管理。圖書信息管理包括圖書征訂、借還、查詢等操作,系統(tǒng)用戶管理包括用戶類別和用戶數(shù)量管理,讀者數(shù)據(jù)管理包括讀者類別管理和個人數(shù)據(jù)的錄入、修改和刪除。</p><p>  2.2可行性分析研究</p><p>  

33、當接受一個軟件開發(fā)任務(wù),就進入軟件生命的第一個階段,即進行可行性的研究。并不是所有問題具有簡單的解決辦法,許多問題不能在預(yù)定的規(guī)模之內(nèi)解決。因此通過可行性的研究分析可以知道問題。</p><p>  有無可行性的解決方法,進而避免人力、物力和才力的浪費。在現(xiàn)行系統(tǒng)初步調(diào)查的基礎(chǔ)上就可以提出新系統(tǒng)目標,即新系統(tǒng)建立后所要求達到的運行指標,這是系統(tǒng)開發(fā)和評價的依據(jù)。系統(tǒng)目標應(yīng)充分體現(xiàn),直接為小商品銷售管理系統(tǒng)服務(wù),并

34、且,程序可以分期分批實現(xiàn)。但是,需要指出的是,系統(tǒng)目標是不可能在總體規(guī)劃階段就提得非常具體,它還將在開發(fā)過程中逐步明確和定量化。以達到更加出色的程序系統(tǒng)??墒?,目標的提法不盡相同,例如:</p><p>  1.提高圖書管理效率,減輕勞動強度;</p><p>  2.提高信息處理速度和準確性;</p><p>  3.為管理者提供更方便、科學的服務(wù)項目。</

35、p><p>  2.2.1操作可行性</p><p>  本系統(tǒng)是基于B/S模式的管理系統(tǒng),操作過程很簡單,是完全可以實現(xiàn)的。對操作系統(tǒng)的要求是Window XP\7系統(tǒng),還要有Microsoft Visual Studio 2005和Access 2003, 在這之前還需要安裝Microsoft .NET Framework SDK v2.0,這些軟件都可以從網(wǎng)上或其他途徑達到要求。<

36、/p><p>  2.2.2 技術(shù)可行性</p><p>  在Microsoft Visual Studio 2005中使用的是C#語言,控件的代碼可以直接拖動自動生成,在此基礎(chǔ)之上對其進行屬性設(shè)置。對數(shù)據(jù)庫的操作是使用SQL語句進行更改,為了使界面更加美觀,需用PS對圖片進行處理,雖然存在困難,但經(jīng)過不斷的學習可以實現(xiàn)。所以不存在技術(shù)上無法解決的問題。</p><p&g

37、t;  2.2.3 經(jīng)濟可行性</p><p>  該系統(tǒng)適用于技術(shù)工程學院,整體數(shù)據(jù)容量不大,管理的用戶根據(jù)該學校的學生人數(shù)而決定,而且對數(shù)據(jù)的存儲量不大,對以往的借書、還書記錄沒有備份的功能,更節(jié)省了開銷,沒有經(jīng)濟方面需要多加關(guān)注的問題。</p><p><b>  2.3結(jié)論意見</b></p><p>  經(jīng)過認真地可行性研究,系統(tǒng)基本

38、上做到了在技術(shù)、經(jīng)濟、運行、法律上的可行。因此,相信在按照計劃上實施的前提下,全系統(tǒng)的設(shè)計將會按時、高質(zhì)量完成。所以,系統(tǒng)研制和開發(fā)是可以馬上進行的。</p><p>  第3章 系統(tǒng)總體設(shè)計</p><p><b>  3.1系統(tǒng)設(shè)計思想</b></p><p>  圖書館管理系統(tǒng)主要應(yīng)具有以下功能:圖書借閱者的需求是查詢圖書館所存的圖書、個

39、人借閱情況及個人信息;圖書館工作人員對圖書借閱者的借閱及還書要求進行操作,同時形成借書和還書報表給借閱者查看和確認;圖書館管理人員的功能最為復雜,包括對工作人員、圖書借閱者、圖書進行管理和維護,以及對系統(tǒng)狀態(tài)的查看、維護等。</p><p>  圖書借閱者可以直接查看圖書管的圖書情況,如果圖書借閱者根據(jù)本人借書證號和密碼登陸系統(tǒng),還可以進行本人借書情況的查詢和部分個人信息的維護。一般情況下,圖書借閱者只可以查詢和

40、維護本人的借書情況和個人信息,若要查詢和維護其他借閱者的結(jié)束情況和個人信息,就要知道其他圖書借閱者的借書證號和密碼。這些是很難得到的,特別是密碼,所以不但滿足了圖書借閱者的要求,還保護了圖書借閱者的個人隱私。</p><p>  圖書館工作人員有修改圖書借閱者借書和還書記錄的權(quán)限,所以需要對圖書館工作人員登錄本模塊進行更多的考慮。在此模塊中,圖書館工作人員可以為圖書借閱者添加借書記錄或者還書記錄,并打印生成相應(yīng)的

41、報表給用戶查看和確認。</p><p>  圖書館管理人員的信息量很大,數(shù)據(jù)安全性和保密性要求高。本功能實現(xiàn)對圖書信息、借閱信息、總體借閱信息的管理和統(tǒng)計、對工作人員信息和管理人員信息的查看和維護。圖書館管理人員可以瀏覽、查詢、添加、刪除、修改、統(tǒng)計圖書的基本信息;瀏覽、查詢、添加、刪除、修改、統(tǒng)計圖書借閱者的基本信息;瀏覽、查詢、統(tǒng)計圖書館的借閱信息,但不能添加、刪除和修改借閱信息。這部分功能應(yīng)該由圖書館工作人

42、員執(zhí)行。</p><p><b>  具體功能如下</b></p><p>  設(shè)計不同用戶的操作權(quán)限和登陸方式;</p><p>  對所有用戶開放的圖書查詢;</p><p>  借閱者維護部分個人信息;</p><p>  借閱者查看個人借閱信息;</p><p> 

43、 維護借閱者個人密碼;</p><p>  根據(jù)借閱情況對數(shù)據(jù)庫進行操作并生成報表;</p><p>  根據(jù)還書情況對數(shù)據(jù)庫進行操作并生成報表;</p><p>  查詢及統(tǒng)計各種信息;</p><p><b>  維護圖書信息;</b></p><p>  維護工作人員和管理人員信息;<

44、/p><p><b>  維護借閱者信息。</b></p><p>  3.2系統(tǒng)功能模塊圖</p><p>  圖3.1 系統(tǒng)功能模塊圖</p><p><b>  3.3系統(tǒng)流程圖</b></p><p><b>  3.4 程序流程圖</b></

45、p><p>  依據(jù)軟件工程的基本原理,詳細設(shè)計階段的根本任務(wù)是確定應(yīng)該怎樣具體實現(xiàn)所要求的系統(tǒng),也就是說,經(jīng)過這個階段的設(shè)計工作,應(yīng)該得出對目標系統(tǒng)的精確描述,從而在系統(tǒng)實現(xiàn)階段可以把這個描述直接翻譯成用某種程序設(shè)計語言書寫的程序。具體來說就是把經(jīng)過總體設(shè)計得到的各個模塊詳細的加以描述。</p><p>  下面給出軟件系統(tǒng)的程序流程圖。如圖3.3、3.4、3.5所示。</p>

46、<p>  圖3.3 管理員登錄程序流程圖</p><p>  圖3.4 讀者登錄程序流程圖</p><p>  圖3.5 工作人員登陸程序流程圖</p><p><b>  3.5功能模塊設(shè)計</b></p><p>  通過對用戶需求和系統(tǒng)設(shè)計思想的分析,可以得出該圖書館管理信息系統(tǒng)大致可以分為幾個大模塊

47、:圖書管理人員維護管理模塊、圖書館工作人員借還管理模塊、借閱者查詢模塊。</p><p>  1 圖書管理人員維護管理模塊</p><p>  系統(tǒng)管理模塊:系統(tǒng)用戶身份的分類、錄入、修改和刪除;</p><p>  圖書管理模塊:圖書數(shù)據(jù)的錄入、修改、刪除和校審等。</p><p>  讀者管理模塊:借閱者個人數(shù)據(jù)的錄入。修改和刪除等。&l

48、t;/p><p>  2 圖書館工作人員借還管理模塊</p><p>  包括圖書的借閱、續(xù)借、返還;圖書借閱數(shù)據(jù)的修改和刪除;圖書書目查詢等。</p><p><b>  3 借閱者查詢模塊</b></p><p>  圖書書目查詢;借閱情況查詢。</p><p>  3.6 程序接口描述</

49、p><p>  3.6.1 外部接口</p><p>  按Windows應(yīng)用軟件用戶界面的規(guī)范來設(shè)計,使用以對話框為主的用戶界面,便于用戶使用。</p><p>  3.6.2 內(nèi)部接口</p><p>  模塊間接口采用數(shù)據(jù)耦合方式,通過參數(shù)表傳送數(shù)據(jù),交換信息。</p><p>  3.7 數(shù)據(jù)庫的設(shè)計</p&

50、gt;<p>  在數(shù)據(jù)庫設(shè)計階段,設(shè)計人員從用戶的角度看待數(shù)據(jù)及處理要求和約束,產(chǎn)生一個反映用戶觀點的概念模式。然后把概念模式轉(zhuǎn)換成邏輯模式。利用ER方法進行數(shù)據(jù)庫的概念設(shè)計,可以分成3步進行:首先設(shè)計局部ER模式,然后把各局部ER模式綜合成一個全局模式,最后對全局ER模式進行優(yōu)化,得到最終的模式,即概念模式。</p><p>  3.7.1 系統(tǒng)設(shè)計局部ER模式</p><

51、p><b>  實體和屬性的定義:</b></p><p>  圖書(編號,名稱,作者,出版社,出版日期,備注,價格,數(shù)量,類別)</p><p>  圖3.6 圖書的ER圖</p><p>  借出圖書(借書證號,圖書編號,借出時間)</p><p>  圖3.7 借出圖書的ER圖</p><

52、p>  借閱者(借書證號,姓名,性別,身份證,電話,密碼,罰款,身份編號)</p><p>  圖3.8 借閱者的ER圖</p><p>  身份(身份編號,身份描述,最大借閱數(shù),最長借閱時間)</p><p>  圖 3.9 登陸人員身份的ER圖</p><p>  圖書類別(圖書類別編號,類別描述)</p><p

53、>  圖3.10 圖書類別的ER圖</p><p>  ER模式的“聯(lián)系”用于刻畫實體之間的關(guān)聯(lián)。一種完整的方式是對局部結(jié)構(gòu)中任意兩個實體類型,依據(jù)需求分析的結(jié)果,考察局部結(jié)構(gòu)中任意兩個實體類型之間是否存在聯(lián)系。若有聯(lián)系,則進一步確定是1:N,M:N,還是1:1 。還要考慮一個實體類型內(nèi)部是否存在聯(lián)系,兩個實體類型之間是否存在聯(lián)系,多個實體類型之間是否存在聯(lián)系等??梢钥偨Y(jié)出如下規(guī)律:</p>

54、<p>  一個借閱者(用戶)只能具有一種身份,而一個身份可以被多個借閱者所具有;</p><p>  一本圖書只能屬于一種圖書類型(類別),而一種圖書類型可以包含多本圖書;</p><p>  一個用戶可以節(jié)約多本不同的圖書,而一本圖書也可以被多個不同的用戶所借閱。</p><p>  3.7.2.系統(tǒng)設(shè)計全局ER模式</p><p&

55、gt;  所有局部ER模式都涉及好了以后,接下來就是把他們綜合成單一的全局概念結(jié)構(gòu)。全局概念結(jié)構(gòu)不僅要直接所有局部ER模式,而且必須合理地表示一個完整,一致的數(shù)據(jù)庫概念結(jié)構(gòu)。為了提高數(shù)據(jù)庫系統(tǒng)的效率,還應(yīng)該進一步依據(jù)處理要求外,還應(yīng)滿足一下條件:</p><p>  實體類型的個數(shù)要盡可能的少;</p><p>  實體類型所含屬性個數(shù)盡可能的少;</p><p>

56、  實體類型之間聯(lián)系無冗余。</p><p>  “圖書借閱管理系統(tǒng)”的全局ER模式如下圖4.7所示。</p><p>  3.7.3數(shù)據(jù)庫邏輯設(shè)計</p><p>  根據(jù)數(shù)據(jù)庫的概念設(shè)計,得出數(shù)據(jù)庫的邏輯設(shè)計。系統(tǒng)數(shù)據(jù)庫名稱為libraryMIS,數(shù)據(jù)庫中包括:①圖書信息表(book);②借出圖書信息表(bookOut);③借閱者信息表(person):④身份信

57、息表(identity);⑤圖書類別信息表(type);⑥管理員信息表(manager)。下面列出各個表的數(shù)據(jù)結(jié)構(gòu):</p><p>  表3.1 圖書信息表(book)的數(shù)據(jù)結(jié)構(gòu)</p><p>  表3.2 借出圖書信息表(bookOut)的數(shù)據(jù)結(jié)構(gòu)</p><p>  表3.3 身份信息表(identity)的數(shù)據(jù)結(jié)構(gòu)</p><p>

58、  表3.4 借閱者信息表(person)的數(shù)據(jù)結(jié)構(gòu)</p><p>  表3.5圖書類別信息表(type)的數(shù)據(jù)結(jié)構(gòu)</p><p>  表4.6 管理員信息表(manager)的數(shù)據(jù)結(jié)構(gòu)</p><p>  3.8系統(tǒng)主要數(shù)據(jù)字典</p><p>  第4章 程序設(shè)計與編碼</p><p><b>  

59、4.1數(shù)據(jù)庫連接</b></p><p>  本系統(tǒng)采用Access文件數(shù)據(jù)庫,降低了程序?qū)τ布僮飨到y(tǒng)版本的要求。并且Access數(shù)據(jù)庫操作方便,配置簡單,只需把數(shù)據(jù)庫文件放置到合適的目錄下即可。</p><p><b>  數(shù)據(jù)庫連接代碼</b></p><p>  Usingsystem</p><p&g

60、t;  Namespace MasterMIS.database</p><p><b>  {</b></p><p>  ///<summary></p><p>  ///dbConnection的摘要說明</p><p>  Public class dbConnection</p>&

61、lt;p><b>  {</b></p><p>  Public dbConnection()</p><p><b>  {</b></p><p><b>  }</b></p><p>  Public static string connection</p

62、><p><b>  {</b></p><p><b>  Get</b></p><p>  {return”Data Source=libraryMIS.mdb;Jet OLEDB:Engine Type=5;</p><p>  Provider=Microsoft.Jet.OLEDB.4.0;

63、”}</p><p><b>  }</b></p><p><b>  }}</b></p><p><b>  數(shù)據(jù)庫調(diào)用代碼</b></p><p>  Private OleDbConnection oleConnection1=new</p><

64、p>  OleDbConnection(LibraryMIS.database.dbConnection.connection);</p><p>  4.2系統(tǒng)管理設(shè)計 </p><p>  在主界面中選擇【系統(tǒng)管理】|【添加用戶】命令菜單或單擊工具欄上的“系統(tǒng)”按鈕,即可進入添加用戶界面,如下圖4.1所示。在該界面可以建立新的用戶,并為用戶選擇角色,賦予權(quán)限。單擊【確定】按鈕,

65、如果用戶信息輸入完整并且用戶名稱不重復則顯示添加成功,否則添加失敗。</p><p>  圖4.1 添加用戶界面</p><p>  在該窗體中設(shè)計了3個TextBox控件、2個Button控件和2個RadioButton控件。各個控件的名稱、作用如表4.1所示</p><p>  表4.1 添加用戶界面控件設(shè)計</p><p><b

66、>  代碼實現(xiàn)如下:</b></p><p>  private void btAdd_Click(object sender, System.EventArgs e)</p><p><b>  {</b></p><p>  if (textName.Text.Trim()==""||textPassw

67、ord.Text.Trim()==""||textPWDNew.Text.Trim()==""||radioManage.Checked==false&&radioWork.Checked==false)</p><p><b>  {</b></p><p>  MessageBox.Show("請輸

68、入完整信息!","警告");</p><p><b>  } </b></p><p><b>  else</b></p><p><b>  {</b></p><p>  if (textPassword.Text.Trim()!=textP

69、WDNew.Text.Trim())</p><p><b>  {</b></p><p>  MessageBox.Show("兩次密碼輸入不一致!","警告");</p><p><b>  } </b></p><p><b>  else&

70、lt;/b></p><p><b>  {</b></p><p>  oleConnection1.Open();</p><p>  OleDbCommand cmd = new OleDbCommand("",oleConnection1);</p><p>  string sql =

71、 "select * from manager where MName = '"+textName.Text.Trim()+"'";</p><p>  cmd.CommandText = sql;</p><p>  if (null == cmd.ExecuteScalar())</p><p><b

72、>  {</b></p><p>  if (radioManage.Checked==true)</p><p>  sql = "insert into manager "+</p><p>  "values ('"+textName.Text.Trim()+"','

73、"+textPWDNew.Text.Trim()+"',true,false,false)";</p><p><b>  else</b></p><p>  sql = "insert into manager "+</p><p>  "values ('&qu

74、ot;+textName.Text.Trim()+"','"+textPWDNew.Text.Trim()+"',false,true,false)";</p><p>  cmd.CommandText = sql;</p><p>  cmd.ExecuteNonQuery();</p><p> 

75、 MessageBox.Show("添加用戶成功!","提示");</p><p>  this.Close();</p><p><b>  } </b></p><p><b>  else</b></p><p><b>  {</b&g

76、t;</p><p>  MessageBox.Show("用戶名"+textName.Text.Trim()+"已經(jīng)存在!","提示");</p><p>  textPWDNew.Text = "";</p><p>  textPassword.Text="";

77、</p><p><b>  }</b></p><p>  oleConnection1.Close();</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b>&l

78、t;/p><p>  private void btClose_Click(object sender, System.EventArgs e)</p><p><b>  {</b></p><p>  this.Close();</p><p><b>  }</b></p><

79、p><b>  }</b></p><p><b>  }</b></p><p>  在主界面中選擇【系統(tǒng)管理】|【瀏覽用戶】命令菜單,即可進入瀏覽用戶界面,如圖4.2所示。在該界面可以顯示圖書館所有工作人員的信息,并可以刪除用戶。該界面中有一個DataGrid控件,控件名稱是DataGrid1,用來顯示用戶信息。</p>

80、<p>  圖4.2 瀏覽用戶界面</p><p>  在該窗體中設(shè)計了3個Button控件和1個DataGrid控件。各個控件的名稱、作用如表4.2所示</p><p>  表4.2 添加用戶界面控件設(shè)計</p><p><b>  代碼實現(xiàn)如下:</b></p><p>  private void Use

81、r_Load(object sender, System.EventArgs e)</p><p><b>  {</b></p><p>  oleConnection1.Open();</p><p>  string sql = "select MName as 用戶名,MCode as 密碼,manage as 權(quán)限,work

82、 as 權(quán)限,query as 權(quán)限from manager";</p><p>  OleDbDataAdapter adp = new OleDbDataAdapter(sql,oleConnection1);</p><p>  ds = new DataSet();</p><p>  ds.Clear();</p><p>

83、;  adp.Fill(ds,"user");</p><p>  dataGrid1.DataSource = ds.Tables["user"].DefaultView;</p><p>  dataGrid1.CaptionText = "共有"+ds.Tables["user"].Rows.Count+

84、"條記錄";</p><p>  oleConnection1.Close();</p><p><b>  }</b></p><p>  ModifyUser modifyUser;</p><p>  private void btModify_Click(object sender, Syst

85、em.EventArgs e)</p><p><b>  {</b></p><p>  if (dataGrid1.CurrentRowIndex>=0&&dataGrid1.DataSource!=null&&dataGrid1[dataGrid1.CurrentCell]!=null)</p><p&g

86、t;<b>  {</b></p><p>  modifyUser = new ModifyUser();</p><p>  modifyUser.textName.Text = ds.Tables[0].Rows[dataGrid1.CurrentCell.RowNumber][0].ToString().Trim();</p><p>

87、  modifyUser.ShowDialog();</p><p><b>  }</b></p><p><b>  }</b></p><p>  private void btDel_Click(object sender, System.EventArgs e)</p><p><b

88、>  {</b></p><p>  if (dataGrid1.CurrentRowIndex>=0&&dataGrid1.DataSource!=null&&dataGrid1[dataGrid1.CurrentCell]!=null)</p><p><b>  {</b></p><p

89、>  oleConnection1.Open();</p><p>  string sql="delete * from manager where MName = '"+ds.Tables["user"].Rows[dataGrid1.CurrentCell.RowNumber][0].ToString().Trim()+"'"

90、;</p><p>  OleDbCommand cmd = new OleDbCommand(sql,oleConnection1);</p><p>  cmd.ExecuteNonQuery();</p><p>  MessageBox.Show("刪除用戶'"+ds.Tables[0].Rows[dataGrid1.Curren

91、tCell.RowNumber][0].ToString().Trim()+"'成功","提示");</p><p>  oleConnection1.Close();</p><p><b>  } </b></p><p><b>  else</b></p>

92、<p><b>  return;</b></p><p><b>  }</b></p><p>  private void btClose_Click(object sender, System.EventArgs e)</p><p><b>  {</b></p>

93、<p>  this.Close();</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p><b>  4.3圖書管理設(shè)計</b></p><

94、;p>  在主界面中選擇【圖書管理】|【圖書分類】命令菜單,即可進入瀏覽圖書分類界面,如圖4.3所示。</p><p>  圖4.3 瀏覽圖書分類界面</p><p>  該界面中共有1個DataGrid控件和4個Button控件,分別是:【添加】(BtAdd)、【修改】(BtModify)、【刪除】(BtDel)和【退出】(BtClose)。</p><p>

95、;<b>  代碼實現(xiàn)如下:</b></p><p>  private void Type_Load(object sender, System.EventArgs e)</p><p>  {oleConnection1.Open();</p><p>  string sql = "select type as 類型,tRema

96、rk as 類型描述,TID as 類型編號from type";</p><p>  OleDbDataAdapter adp = new OleDbDataAdapter(sql,oleConnection1);</p><p>  ds = new DataSet();</p><p>  ds.Clear();</p><p&g

97、t;  adp.Fill(ds,"type");</p><p>  dataGrid1.DataSource = ds.Tables["type"].DefaultView;</p><p>  dataGrid1.CaptionText = "共有"+ds.Tables["type"].Rows.Count

98、+"條記錄";</p><p>  oleConnection1.Close();</p><p><b>  }</b></p><p>  AddType addType;</p><p>  private void btAdd_Click(object sender, System.Event

99、Args e)</p><p>  {addType = new AddType();</p><p>  addType.ShowDialog();</p><p><b>  }</b></p><p>  ModifyType modifyType;</p><p>  private v

100、oid btModify_Click(object sender, System.EventArgs e)</p><p>  {if (dataGrid1.DataSource != null || dataGrid1[dataGrid1.CurrentCell] != null)</p><p>  {modifyType = new ModifyType();</p>

101、<p>  modifyType.textName.Text=ds.Tables["type"].Rows[dataGrid1.CurrentCell.RowNumber][0].ToString().Trim();</p><p>  modifyType.textRemark.Text=ds.Tables["type"].Rows[dataGrid1.Cur

102、rentCell.RowNumber][1].ToString().Trim();</p><p>  modifyType.Tag=ds.Tables["type"].Rows[dataGrid1.CurrentCell.RowNumber][2].ToString().Trim();</p><p>  modifyType.Show();</p>&

103、lt;p><b>  }</b></p><p><b>  else</b></p><p>  MessageBox.Show("沒有指定類型信息!","提示");</p><p><b>  }</b></p><p>  p

104、rivate void btDel_Click(object sender, System.EventArgs e)</p><p>  {if (dataGrid1.CurrentRowIndex>=0&&dataGrid1.DataSource!=null&&dataGrid1[dataGrid1.CurrentCell]!=null)</p><p&

105、gt;  {oleConnection1.Open();</p><p>  string sql="select * from book where type='"+ds.Tables["type"].Rows[dataGrid1.CurrentCell.RowNumber][0].ToString().Trim()+"'";</

106、p><p>  OleDbCommand cmd = new OleDbCommand(sql,oleConnection1);</p><p>  OleDbDataReader dr;</p><p>  dr = cmd.ExecuteReader();</p><p>  if (dr.Read())</p><p&g

107、t;<b>  {</b></p><p>  MessageBox.Show("刪除類型'"+ds.Tables["type"].Rows[dataGrid1.CurrentCell.RowNumber][0].ToString().Trim()+"'失敗,請先刪掉該類型圖書!","提示");&

108、lt;/p><p>  dr.Close();</p><p><b>  } </b></p><p><b>  else</b></p><p><b>  {</b></p><p>  dr.Close();</p><p>

109、;  sql = "delete * from type where type not in(select distinct type from book) and TID "+</p><p>  "= "+ds.Tables["type"].Rows[dataGrid1.CurrentCell.RowNumber][2].ToString().Tri

110、m()+"";</p><p>  cmd.CommandText = sql;</p><p>  cmd.ExecuteNonQuery();</p><p>  MessageBox.Show("刪除類型'"+ds.Tables[0].Rows[dataGrid1.CurrentCell.RowNumber][0

111、].ToString().Trim()+"'成功","提示");</p><p><b>  }</b></p><p>  oleConnection1.Close();</p><p><b>  } </b></p><p><b> 

112、 else</b></p><p><b>  return;</b></p><p><b>  }</b></p><p>  private void btClose_Click(object sender, System.EventArgs e)</p><p><b>

113、;  {</b></p><p>  this.Close();</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  單擊【添加】按鈕進入添加圖書類型界面

114、,如圖4.4 所示。</p><p>  圖4.4 添加圖書類型界面</p><p>  用戶可以在這個窗體中設(shè)置圖書類型信息。單擊【確定】按鈕,如果圖書類型信息輸入完整并且圖書類型不重復則顯示添加成功,否則添加失敗。該窗體中設(shè)計了2個TextBox控件和2個Button控件。各個控件的名稱、作用如表4.3所示。</p><p>  表4.3 新建角色界面控制設(shè)計

115、</p><p><b>  代碼實現(xiàn)如下:</b></p><p>  private void btAdd_Click(object sender, System.EventArgs e)</p><p><b>  {</b></p><p>  if (textName.Text.Trim(

116、)==""||textRemark.Text.Trim()=="")</p><p>  MessageBox.Show("請?zhí)顚懲暾畔?quot;,"提示");</p><p><b>  else</b></p><p><b>  {</b>&l

117、t;/p><p>  oleConnection1.Open();</p><p>  string sql = "select * from type where type='"+textName.Text.Trim()+"'";</p><p>  OleDbCommand cmd = new OleDbCom

118、mand(sql,oleConnection1);</p><p>  if (null!=cmd.ExecuteScalar())</p><p>  MessageBox.Show("類型重復,請重新輸入!","提示");</p><p><b>  else</b></p><p

119、><b>  {</b></p><p>  sql="insert into type (type,tRemark) values ('"+textName.Text.Trim()+"','"+textRemark.Text.Trim()+"')";</p><p> 

120、 cmd.CommandText = sql;</p><p>  cmd.ExecuteNonQuery();</p><p>  MessageBox.Show("類型添加成功!","提示");</p><p>  textName.Clear();</p><p>  textRemark.Cle

121、ar();</p><p><b>  }</b></p><p>  oleConnection1.Close();</p><p><b>  }</b></p><p><b>  }</b></p><p>  private void btCl

122、ose_Click(object sender, System.EventArgs e)</p><p><b>  {</b></p><p>  this.Close();</p><p><b>  }</b></p><p><b>  }</b></p>

123、<p><b>  }</b></p><p>  在主界面中選擇【圖書管理】|【瀏覽】命令菜單,即可進入瀏覽圖書界面,如圖4.5所示。</p><p>  圖4.5 瀏覽圖書界面</p><p>  該界面中共有1個DataGrid控件和4個Button控件,分別是:【添加】(BtAdd)、【修改】(BtModify)、【刪除】(

124、BtDel)和【退出】(BtClose)。</p><p><b>  代碼實現(xiàn)如下:</b></p><p>  private void Book_Load(object sender, System.EventArgs e)</p><p><b>  {</b></p><p>  oleC

125、onnection1.Open();</p><p>  string sql = "select BID as 圖書編號,BName as 圖書名,BWriter as 作者,BPublish as 出版社,BDate as 出版日期,BPrice as 價格,"+</p><p>  "BNum as 數(shù)量,type as 類型,BRemark as 備注

126、from book";</p><p>  OleDbDataAdapter adp = new OleDbDataAdapter(sql,oleConnection1);</p><p>  ds = new DataSet();</p><p>  ds.Clear();</p><p>  adp.Fill(ds,"

溫馨提示

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

評論

0/150

提交評論