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

下載本文檔

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

文檔簡介

1、<p><b>  畢業(yè)論文(設(shè)計)</b></p><p><b>  目錄</b></p><p><b>  第1章 緒論4</b></p><p><b>  1.1軟件概述4</b></p><p><b>  1.2系統(tǒng)

2、介紹4</b></p><p>  1.3開發(fā)工具簡介4</p><p>  第2章 總體設(shè)計分析5</p><p><b>  2.1解決方案5</b></p><p>  2.2業(yè)務(wù)流程分析6</p><p>  2.3數(shù)據(jù)流程圖分析6</p><p

3、><b>  2.4數(shù)據(jù)字典7</b></p><p><b>  2.5處理描述8</b></p><p>  2.6系統(tǒng)功能結(jié)構(gòu)9</p><p>  2.7數(shù)據(jù)庫的設(shè)計9</p><p>  第3章 圖書管理系統(tǒng)詳細(xì)設(shè)計12</p><p>  3.1主

4、窗體的設(shè)計12</p><p>  3.2登陸窗體設(shè)計13</p><p>  3.3添加記錄窗體設(shè)計13</p><p>  3.3.1讀者數(shù)據(jù)增加14</p><p>  3.3.2讀者類型管理16</p><p>  3.3.3圖書信息增加18</p><p>  3.3.4圖

5、書類型管理20</p><p>  3.3.5圖書借閱歸還窗體21</p><p>  3.4數(shù)據(jù)更新窗體設(shè)計27</p><p>  3.4.1圖書數(shù)據(jù)更新27</p><p>  3.4.2讀者數(shù)據(jù)更新29</p><p>  3.5數(shù)據(jù)查詢窗體設(shè)計32</p><p>  3.

6、5.1圖書查詢設(shè)計32</p><p>  3.5.2讀者信息查詢設(shè)計34</p><p>  第4章 結(jié)束語37</p><p><b>  參考文獻(xiàn)37</b></p><p><b>  圖書管理系統(tǒng)的設(shè)計</b></p><p>  摘 要:圖書管理系統(tǒng)是典

7、型的信息管理系統(tǒng)(MIS),其開發(fā)主要包括后臺數(shù)據(jù)庫的建立和維護(hù)以及前端應(yīng)用程序的開發(fā)兩個方面。對于前者要求建立起數(shù)據(jù)一致性和完整性強(qiáng)、數(shù)據(jù)安全性好的庫。而對于后者則要求應(yīng)用程序功能完備,易使用等特點。 </p><p>  因此本人結(jié)合開入式圖書館的要求,對MS SQL Server2000數(shù)據(jù)庫管理系統(tǒng)、SQL語言原理、Delphi應(yīng)用程序設(shè)計,Delphi數(shù)據(jù)庫技術(shù)進(jìn)行了較深入的學(xué)習(xí)和應(yīng)用,主要完成對圖書管

8、理系統(tǒng)的需求分析、功能模塊劃分、數(shù)據(jù)庫模式分析,并由此設(shè)計了數(shù)據(jù)庫結(jié)構(gòu)和應(yīng)用程序。系統(tǒng)運行結(jié)果證明,本文所設(shè)計的圖書管理系統(tǒng)可以滿足借閱者、圖書館工作人員和高級管理員三方面的需要。 實現(xiàn)了數(shù)據(jù)庫表的瀏覽,記錄的添加、刪除和修改,報表的生成,實現(xiàn)了多數(shù)據(jù)庫表的連接操作,實現(xiàn)了多條件查詢和模糊查詢,并靈活實現(xiàn)了對不可更新查詢結(jié)果集的更新操作,實現(xiàn)了主從表操作,實現(xiàn)了密碼維護(hù)功能,最后,系統(tǒng)還可以導(dǎo)入數(shù)據(jù)庫以對任意同結(jié)構(gòu)的數(shù)據(jù)庫進(jìn)行操作。 設(shè)

9、計充分利用Delphi7.0、數(shù)據(jù)庫技術(shù)的強(qiáng)大力量,提高了編程效率和可靠性。 </p><p>  關(guān)鍵詞:數(shù)據(jù)庫;Delphi7.0;數(shù)據(jù)庫組件;圖書管理;窗體</p><p><b>  第1章 緒論</b></p><p><b>  1.1軟件概述</b></p><p>  此軟件是運行在

10、Windows下的用與對圖書館圖書信息,以及用戶借閱信息進(jìn)行記錄的和管理的軟件。利用delphi進(jìn)行開發(fā),數(shù)據(jù)通過附帶的database desktop工具以表的方式錄入保存,運用sql語句進(jìn)行查詢</p><p>  該系統(tǒng)擁有漂亮的圖形化界面,操作簡便,能完成添加圖書信息,修改圖書信息,查詢圖書信息,添加讀者類別,修改讀者類別,查詢讀者信息,修改讀者信息等一系列圖書管理功能,開發(fā)本系統(tǒng)的總體任務(wù)是實現(xiàn)圖書管理

11、的系統(tǒng)化和自動化,幫助管理人員更好更高效地完成圖書管理工作。</p><p><b>  1.2系統(tǒng)介紹</b></p><p>  隨著圖書館規(guī)模的不斷擴(kuò)大,圖書數(shù)量也相應(yīng)的增加,有關(guān)圖書的各種信息量也成倍增加,面對這龐大的信息量,傳統(tǒng)的人工方式管理會導(dǎo)致圖書館管理上的混亂,由于是用手工進(jìn)行抄寫,且數(shù)據(jù)處理工作量大,容易出錯。并且數(shù)據(jù)繁多,容易造成丟失,不易查找。人

12、力與物力過多浪費,圖書館管理費用也會增加,從而使圖書館的負(fù)擔(dān)過重,影響整個圖書館的運作和控制管理,因此,必須制定一套合理、有效,規(guī)范和實用的圖書管理系統(tǒng),對圖書資料進(jìn)行集中統(tǒng)一的管理。</p><p><b>  1.3開發(fā)工具簡介</b></p><p>  本系統(tǒng)采用Delphi 7.0作為開發(fā)平臺,它是操作系統(tǒng)中快速應(yīng)用開發(fā)環(huán)境的最新版本。它也是當(dāng)前Window

13、s平臺上第一個全面支持最新Web服務(wù)的快速開發(fā)工具。無論是企業(yè)級用戶,還是個人開發(fā)者,都能夠利用Delphi 7.0輕松、快捷地構(gòu)建新一代電子商務(wù)應(yīng)用。Delphi 7.0 是惟一支持所有新出現(xiàn)的工業(yè)標(biāo)準(zhǔn)的RAD環(huán)境,包括XML(擴(kuò)展標(biāo)記語言)/XSL(可擴(kuò)展樣式語言),SOAP(簡單對象存取協(xié)議)和WSDL(Web服務(wù)器描述語言)等。</p><p>  Delphi 7.0 是可視化的快速應(yīng)用程序開發(fā)語言,它

14、提供了可視化的集成開發(fā)環(huán)境,這一環(huán)境為應(yīng)用程序設(shè)計人員提供了一系列靈活而先進(jìn)的工具,可以廣泛地用于種類應(yīng)用程序設(shè)計。在Delphi 7.0 的集成開發(fā)環(huán)境中,用戶可以設(shè)計程序代碼、運行程序、進(jìn)行程序錯誤的調(diào)試等,可視化的開發(fā)方法降低了應(yīng)用程序開發(fā)的難度。Delphi 7.0的基礎(chǔ)編程語言是具有面向?qū)ο筇匦缘腜ascal語言,即Object Pascal 。Object Pascal具有代碼穩(wěn)定、可讀性好、編譯速度快等優(yōu)點,并將面向?qū)ο蟮?/p>

15、概念移使用Delph 7.0 ,我們幾乎可以作任何事情,還可以撰寫種各種類型的應(yīng)用程序,動態(tài)鏈接庫(DLL)、CON、或CORBA對象,CGI/ISAPI程序,Microsoft Back Office應(yīng)用程序。程序的規(guī)模小到簡單的個人數(shù)據(jù)庫應(yīng)用,大到復(fù)雜的企業(yè)的多層次分布式系統(tǒng),都可以使用Delphi進(jìn)行開發(fā),其友好的集成開發(fā)界面,可視化的雙向開發(fā)模式,良好的數(shù)據(jù)庫應(yīng)用支持高效的程序開發(fā)和程序運行,備受廣大程序開發(fā)人員的好評。尤其是D

16、elphi7.0對數(shù)據(jù)庫應(yīng)用的強(qiáng)大支持,大大提高了數(shù)據(jù)庫應(yīng)用軟件</p><p>  第2章 總體設(shè)計分析</p><p>  此軟件的開發(fā)將根據(jù)用戶的需求,按照用戶的意圖以及應(yīng)用目標(biāo)和范圍進(jìn)行設(shè)計。從權(quán)限角度考慮,在登陸窗體中,我們就必須設(shè)置系統(tǒng)管理員,來賓用戶,一般用戶等選項,并對系統(tǒng)管理員選項要設(shè)置口令密碼,才能登陸??蚣苌蟻碇v,一個系統(tǒng)要對圖書進(jìn)行管理,就必須要有圖書類別,名稱,編

17、號等各項目進(jìn)行統(tǒng)計,這樣新書上架,圖書的借閱歸還的狀態(tài),我們都能清除的了解到。從讀者角度來考慮,我們必須能添加新的讀者,并對讀者的具體情況,進(jìn)行管理。解決了這些問題這就給我們以后模塊的設(shè)計提供了思路。</p><p><b>  2.1解決方案</b></p><p>  通過對圖書館工作流程的研究和詳細(xì)地詢問有關(guān)人員,對圖書館的各個方面的工作流程有了具體的了解,經(jīng)過

18、和圖書館的相關(guān)人員協(xié)商后,最終確定在圖書管理系統(tǒng)中要具有以下幾方面的內(nèi)容:</p><p>  1.具有信息錄入功能</p><p>  ※圖書庫的錄入(入庫功能)包括的內(nèi)容是圖書編號,分類號,種類號,圖書名稱,圖書作者,出版社,單價,開本,進(jìn)庫日期。</p><p>  ※ 讀者庫的錄入包括的內(nèi)容是借書證號,姓名,性別,單位,辦證日期,讀者類型。</p>

19、;<p>  2.具有圖書流通功能</p><p><b>  ※ 讀者借閱圖書。</b></p><p>  ※ 讀者能夠歸還讀書,如果圖書超期,提示超期的天數(shù)和應(yīng)罰款金額。</p><p>  3.具有信息的存儲功能</p><p>  對系統(tǒng)的所有操作功能能夠存儲。也就是系統(tǒng)可以存諸圖書信息,讀者信息

20、,借書、還書信息等。</p><p><b>  4.具有瀏覽功能</b></p><p>  ※能夠濟(jì)覽圖書的詳細(xì)信息。</p><p>  ※能夠瀏覽讀者的詳細(xì)信息。</p><p>  ※能夠瀏覽圖書的清單,以及圖書流通情況。</p><p><b>  5.具有查詢功能</

21、b></p><p>  ※能夠按照讀者的借書證號查詢讀者的相關(guān)信息。</p><p>  ※能夠按照讀者的借書證號查詢讀者的借況情況。</p><p>  ※能夠按照圖書的關(guān)鍵字(圖書編號,書名,作者等)查詢相關(guān)信息。</p><p><b>  6.具有特殊功能</b></p><p>

22、  ※進(jìn)入系統(tǒng)時要求提供操作者姓名和密碼。</p><p>  ※可以設(shè)置讀者類型的借閱期限和借閱冊數(shù)。</p><p><b>  2.2業(yè)務(wù)流程分析</b></p><p><b>  圖1 業(yè)務(wù)流程圖</b></p><p>  2.3數(shù)據(jù)流程圖分析</p><p>

23、  數(shù)據(jù)流程圖(Data Flow DFD)是描述實際業(yè)務(wù)管理系統(tǒng)工作流程的一種圖形表示法。它描繪系統(tǒng)的邏輯模型圖,其中沒有任何具體的物理元素,只是描繪信息在系統(tǒng)中流動和處理的情況。因為數(shù)據(jù)流圖是邏輯系統(tǒng)的圖形表示,即使不是專業(yè)的計算機(jī)技術(shù)人員也容易理解,所以是極好的通信工具。此外,設(shè)計數(shù)據(jù)流圖只需考慮系統(tǒng)必須完成的基本邏輯功能,完全不需要考慮如何具體地實現(xiàn)這些功能,所以它也是軟件設(shè)計的很好的出發(fā)點?!秷D書管理系統(tǒng)》主要是為了對圖書、讀

24、者基本信息等進(jìn)行計算機(jī)管理。下面就是對各個步驟的流程分析:(1)登陸窗體,選擇用戶類型;(2)輸入密碼口令;(3)進(jìn)入系統(tǒng);(4)實現(xiàn)各種操作;(5退出系統(tǒng))。綜合上面的介紹,下面講總體的流程圖分析如圖2:</p><p>  圖2 系統(tǒng)數(shù)據(jù)流程圖</p><p><b>  2.4數(shù)據(jù)字典</b></p><p><b> ?。?

25、)數(shù)據(jù)流字典</b></p><p>  ① 數(shù)據(jù)流名稱:新書入庫單 標(biāo)識符:TS1</p><p><b>  數(shù)據(jù)結(jié)構(gòu):</b></p><p><b>  01新書入庫單</b></p><p>  02日期(RQ)

26、 TS1(10)</p><p>  02圖書代碼(CPDM) TS1(12)</p><p>  02圖書名稱(CPMC) TS1(18)</p><p>  02出版社名稱(CBCMC) TS1(15)</p><p>  02單位(DW)

27、 TS1(4)</p><p>  02規(guī)格(GG) TS1(10)</p><p>  02入庫數(shù)量(RKSL) TS1(6)</p><p>  排列方式:按圖書類型,分架子排列</p><p>  流量:最大 5000本/次</p><

28、;p><b>  來源:圖書供應(yīng)商</b></p><p>  去向:流通,借出給學(xué)生,老師,其它人員</p><p> ?、?數(shù)據(jù)流名稱:圖書出庫單 標(biāo)識符:TS2</p><p><b>  數(shù)據(jù)結(jié)構(gòu):</b></p><p><b>  01

29、產(chǎn)品出庫單</b></p><p>  02日期(RQ) TS1(10)</p><p>  02圖書代碼(CPDM) TS1(12)</p><p>  02圖書名稱(CPMC) TS1(18)</p><p>  02出版社名稱(CBCMC)

30、 TS1(15)</p><p>  02單位(DW) TS1(4)</p><p>  02規(guī)格(GG) TS1(10)</p><p>  02入庫數(shù)量(RKSL) TS1(6)</p><p>  流量:平均:2000本/次</p>

31、<p>  去向:流通,借出給學(xué)生,老師,其它人員</p><p><b>  2.5處理描述</b></p><p>  ① 處理名:錄入入庫圖書 標(biāo)識符:TS1</p><p><b>  輸入:數(shù)據(jù)流A1</b></p><p><b>  輸出:數(shù)據(jù)流 A2&

32、lt;/b></p><p><b>  處理定義:</b></p><p>  當(dāng)輸入的圖書編號不為空且不為非法字符,日期代碼都正確,并且新的圖書實物入庫后,立即將這張入庫單上的數(shù)據(jù)登入數(shù)據(jù)庫,并記入賬本。</p><p>  激發(fā)條件:圖書入庫發(fā)生時 </p><p> ?、?處理名:登記借出圖書 標(biāo)

33、識符:TS2</p><p>  輸入:輸入圖書的條碼編號</p><p>  輸出:掃描記錄圖書的各種信息,并登記記錄</p><p><b>  處理定義:</b></p><p>  當(dāng)某人借書,且圖書的是已經(jīng)存在在圖書管的,并做了入庫登記的,借出日期與當(dāng)日日期相符。把圖書的相關(guān)信息登記處理</p>

34、<p>  激發(fā)條件:每日借出處理</p><p><b>  2.6系統(tǒng)功能結(jié)構(gòu)</b></p><p>  概念設(shè)計階段主要任務(wù)和目標(biāo)是根據(jù)需求分析的結(jié)果,包括一般聯(lián)系實體,畫出對應(yīng)的結(jié)構(gòu)圖。對于復(fù)雜的系統(tǒng),通常首先要對它的各功能模進(jìn)行分析,模塊化是指解決一個復(fù)雜問題時自項向下逐層把軟件系統(tǒng)劃分成若干個模塊的過程。每個模塊完成一個特定的功能,所有的模塊

35、按某種方法組織起來,成為一個整體,完成整個系統(tǒng)所要求的功能。本系統(tǒng)的主界面包括讀者管理,圖書維護(hù),圖書流通,系統(tǒng)設(shè)置,幫助,以及狀態(tài)欄等六大部分。</p><p>  結(jié)合上面的系統(tǒng)功能模塊分析,下面將本系統(tǒng)的各大功能分別用圖的結(jié)構(gòu)形式分析如下設(shè)計新系統(tǒng)功能結(jié)構(gòu)如圖3所示。</p><p>  圖3 系統(tǒng)功能結(jié)構(gòu)圖</p><p><b>  2.7數(shù)據(jù)庫

36、的設(shè)計</b></p><p>  利用delphi 7.0附帶databasedesktop 工具,各種數(shù)據(jù)信息,都以表的形式保存。在上面的實體以及實體之間關(guān)系的基礎(chǔ)上,形成數(shù)據(jù)庫中的表格以及各個表格之間的關(guān)系。圖書管理信息系統(tǒng)數(shù)據(jù)庫中各個表格的設(shè)計結(jié)果如下面的幾個表格所示,每個表格表示在數(shù)據(jù)庫中的一個表。</p><p><b>  1.讀者庫</b>

37、</p><p>  作用:存放讀者的基本信息表,如表1所示</p><p><b>  表1 讀者信息表</b></p><p><b>  2.讀者類型庫</b></p><p>  作用:存放讀者類型及相關(guān)信息,如表2所示。</p><p>  表2 讀者類型信息表

38、</p><p><b>  借閱記錄</b></p><p>  作用:存放所有的借書信息,如表3所示。</p><p><b>  表3 借閱記錄表</b></p><p><b>  圖書庫</b></p><p>  作用:存放圖書的基本信息,

39、如表4所示。</p><p><b>  表4 圖書信息表</b></p><p><b>  5.圖書類型</b></p><p>  作用:存放圖書的類型信息,如表5所示。</p><p>  表5 圖書類型信息表</p><p><b>  用戶庫<

40、/b></p><p>  作用:存放系統(tǒng)操作員信息,如表6所示。</p><p><b>  表6 用戶信息表</b></p><p>  第3章 圖書管理系統(tǒng)詳細(xì)設(shè)計</p><p><b>  3.1主窗體的設(shè)計</b></p><p>  窗體的制作MDI窗體

41、,一般采用系統(tǒng)自動生成的方法。這種方法簡單但是產(chǎn)生很多用不到的信息。所以在此采用非自動生成的方法。在delphi7中,新建一個Application菜單。這樣系統(tǒng)就有了一個普通窗體。通過修改窗體的”FormStyle”屬性為”fsMDIForm”,這樣就可以把這個窗體改為MDI父窗體了。</p><p>  在這個系統(tǒng)中,進(jìn)入系統(tǒng)后顯示的是一個主窗體,主窗體的背景圖片是一副圖片,同時在主窗體的任務(wù)欄中顯示當(dāng)前的操

42、作者,用戶角色,當(dāng)前日期和當(dāng)前時間,并且日期和時間會隨著系統(tǒng)時間的變化而變化。未了操作上的方便,需要在主窗體中增加工具欄,在這里要實現(xiàn)像辦公軟件中類似的工具欄,為了上述目的,在主窗體中增加了一個Timage組件和一個TcoolBar組件,4個Ttoolbar組件,和8個Ttoolbutton組件,一個Ttimer組件和一個TStatusbar組件。系統(tǒng)主界面如圖4:</p><p><b>  圖4

43、主窗體圖</b></p><p>  事件分析及主要代碼設(shè)置完成各個組件的屬性后,就可以測試運行程序了。運行程序時,發(fā)現(xiàn)各個菜單沒有實現(xiàn)任何功能,這是因為沒有給組件編寫事件代碼。</p><p>  1.實現(xiàn)的功能是在任務(wù)欄中,顯示當(dāng)前日期和時間。雙擊界面中的TTimer組件,出現(xiàn)的代碼窗體中輸入下面代碼:</p><p>  statusbar1.Pa

44、nels[3].Text:=datetostr(date);</p><p>  statusbar1.Panels[4].Text:=timetostr(time);</p><p>  2.背景圖片的顯示和隱藏</p><p>  N_xtsz_back.Checked:=not N_xtsz_back.Checked;</p><p>

45、  Image1.Visible:=N_xtsz_back.Checked;</p><p><b>  4.系統(tǒng)退出代碼</b></p><p>  Application.terminate;//結(jié)束應(yīng)用程序</p><p>  3.2 登陸窗體設(shè)計</p><p>  為了防止其他人員故意或者非故意修改信息。要求系

46、統(tǒng)有一個用戶登陸界面,這也是系統(tǒng)安全性的一個方面。在該界面中,用戶的名稱在一個下拉列表框中,用戶主要選擇操作員名稱就可以了,然后再輸入密碼,當(dāng)密碼輸入正確時,單擊確定按鈕即可進(jìn)入系統(tǒng)否則不讓登陸,密碼三次輸入不正確,系統(tǒng)自動退出。界面如圖4:</p><p><b>  圖4 登陸界面圖</b></p><p><b>  主要代碼分析如下:</b&g

47、t;</p><p>  if not query1.Locate('用戶名;密碼',Vararrayof([combobox_name.Text,</p><p>  password.Text]),[]) then</p><p><b>  begin</b></p><p>  Showmessa

48、ge('密碼不正確,請重新輸入!');</p><p>  Li_Login:=Li_Login+1;</p><p>  password.SetFocus;</p><p>  password.SelectAll;</p><p>  //有3次輸入機(jī)會,3次不正確系統(tǒng)退出//</p><p> 

49、 if Li_Login >=3 then</p><p><b>  begin</b></p><p>  Showmessage('你是非法用戶,系統(tǒng)退出');</p><p><b>  Close;</b></p><p>  Application.Terminat

50、e;</p><p><b>  end;</b></p><p>  3.3添加記錄窗體設(shè)計</p><p>  3.3.1讀者數(shù)據(jù)增加</p><p>  該窗體的作用就是增加讀者信息.讀者信息包括了借書證號、姓名、性別單位、辦證日期、讀者類型。界面如圖5:</p><p>  圖5:讀者信息

51、增加圖</p><p><b>  主要程序代碼如下:</b></p><p>  procedure TForm_dz_input.BitBtn1Click(Sender: TObject);</p><p><b>  var</b></p><p>  S_sql:string;</p&

52、gt;<p><b>  begin</b></p><p>  if dbedit1.Text='' then</p><p><b>  begin</b></p><p>  showmessage('借書證號不能為空');</p><p><

53、;b>  exit;</b></p><p><b>  end ;</b></p><p>  if(length(dbedit1.Text)<>8)then</p><p><b>  begin</b></p><p>  showmessage('你輸入

54、的借書證號格式不對');</p><p><b>  exit;</b></p><p><b>  end;</b></p><p><b>  try</b></p><p>  strtoint(dbedit1.Text);</p><p>

55、;<b>  except</b></p><p>  showmessage('借書證號只能輸入數(shù)字。');</p><p><b>  exit;</b></p><p><b>  end ;</b></p><p>  query3.Close;<

56、/p><p>  query3.SQL.Clear;</p><p>  S_sql:='select *from 讀者庫 where 借書證號='''+dbedit1.Text+'''';</p><p>  query3.SQL.Add(S_sql);</p><p>  que

57、ry3.Open;</p><p>  if query3.RecordCount<>0 then</p><p><b>  begin</b></p><p>  showmessage('該借書證號已經(jīng)存在。');</p><p><b>  exit;</b>&l

58、t;/p><p><b>  end ;</b></p><p>  if dbedit2.Text='' then</p><p><b>  begin</b></p><p>  showmessage('讀者姓名不能為空。');</p><p&

59、gt;<b>  exit;</b></p><p><b>  end;</b></p><p>  if dbedit4.Text='' then</p><p><b>  begin</b></p><p>  showmessage('讀者單位

60、不能為空。');</p><p><b>  exit;</b></p><p><b>  end;</b></p><p>  query1.ApplyUpdates;</p><p>  showmessage('添加讀者'''+dbedit2.Text

61、+'''成功');</p><p>  query1.Append;</p><p><b>  end;</b></p><p><b>  end.</b></p><p>  3.3.2讀者類型管理</p><p>  該窗體主要是編輻讀

62、者類型的。讀者類型信息包括了類型號(主鍵),類型名稱(在讀者增加窗體中顯示)、借閱期限和借閱的冊數(shù)。要求可以增加,刪除,修改讀者類型就可以了。界面如圖6:</p><p>  圖6:讀者類型管理圖</p><p><b>  主要程序代碼如下:</b></p><p>  procedure Tform_edit_dzlx.BitBtn1Cli

63、ck(Sender: TObject);</p><p><b>  begin</b></p><p>  table1.Append;</p><p><b>  end;</b></p><p>  procedure Tform_edit_dzlx.BitBtn2Click(Sender:

64、TObject);</p><p><b>  begin</b></p><p>  table1.Delete;</p><p><b>  end;</b></p><p>  procedure Tform_edit_dzlx.BitBtn3Click(Sender: TObject);&l

65、t;/p><p><b>  begin</b></p><p>  table1.Append;</p><p><b>  end;</b></p><p>  procedure Tform_edit_dzlx.BitBtn4Click(Sender: TObject);</p>&

66、lt;p><b>  begin</b></p><p><b>  Close;</b></p><p><b>  end;</b></p><p>  procedure Tform_edit_dzlx.FormCreate(Sender: TObject);</p><

67、;p><b>  begin</b></p><p>  table1.CachedUpdates:=true;</p><p><b>  end;</b></p><p><b>  end.</b></p><p>  3.3.3 圖書信息增加</p>

68、<p>  建窗體的作用就是增加圖書信息民。圖書信息包括了圖書編號、圖書類型、圖書名稱、圖書作者、出版社、單價、開本、和進(jìn)庫日期等信息。圖書類型是通過類型窗估編輯得到的。根據(jù)需要可以在圖書類型編輯窗體中增加和刪除圖書類型。界面如圖7:</p><p>  圖7:圖書信息增加圖</p><p><b>  主要程序代碼如下:</b></p>&

69、lt;p>  procedure Tform_input_book.BitBtn1Click(Sender: TObject);</p><p><b>  var</b></p><p>  S_sql:string;</p><p><b>  begin</b></p><p>  if

70、 dbedit1.Text='' then</p><p><b>  begin</b></p><p>  showmessage('圖書編號不能為空');</p><p><b>  exit;</b></p><p><b>  end;</b

71、></p><p>  if (length(dbedit1.Text)<>13) then</p><p><b>  begin</b></p><p>  showmessage('你輸入的圖書編號格式不對');</p><p><b>  exit;</b>

72、</p><p><b>  end;</b></p><p><b>  Try</b></p><p>  StrToInt64(dbedit1.Text);</p><p><b>  except</b></p><p>  showmessag

73、e('休想蒙混過關(guān)!圖書編號只能輸入數(shù)字。');</p><p><b>  exit;</b></p><p><b>  end;</b></p><p>  Query1.Close;</p><p>  query1.SQL.Clear;</p><p&g

74、t;  S_sql:='select *from 圖書信息表 where 圖書編號='+""+dbedit1.Text+"";</p><p>  query1.SQL.Add(S_sql);</p><p>  Query1.Open;</p><p>  if query1.RecordCount<&

75、gt;0 then</p><p><b>  begin</b></p><p>  showmessage('該圖書編號已經(jīng)存在。');</p><p><b>  exit;</b></p><p><b>  end;</b></p>&l

76、t;p>  if dbedit3.Text='' then</p><p><b>  begin</b></p><p>  showmessage('圖書名不能為空。');</p><p><b>  exit;</b></p><p><b> 

77、 end;</b></p><p>  if dbedit4.Text='' then</p><p><b>  begin</b></p><p>  showmessage('圖書作者不能為空。');</p><p><b>  exit;</b>&

78、lt;/p><p><b>  end;</b></p><p>  if dbedit5.Text='' then</p><p><b>  begin</b></p><p>  showmessage('圖書出版社不能為空。');</p><p

79、><b>  exit;</b></p><p><b>  end;</b></p><p>  if dbedit6.Text='' then</p><p><b>  begin</b></p><p>  showmessage('單價不

80、能為空。');</p><p><b>  exit;</b></p><p><b>  end;</b></p><p>  if dbedit7.Text='' then</p><p><b>  begin</b></p><

81、;p>  showmessage('開本不能為空。');</p><p><b>  exit;</b></p><p><b>  end;</b></p><p>  table1.ApplyUpdates;</p><p>  showmessage('添加圖書&

82、#39;+''''+dbedit3.text+'''''成功');</p><p>  table1.Append;</p><p><b>  end;</b></p><p><b>  end.</b></p><p&

83、gt;  3.3.4 圖書類型管理</p><p>  該窗體用于設(shè)置圖書的種類,包括圖類型號(主鍵)和圖書類型的名稱(顯示用)。對于功的要求比較簡單,只要可以增加、刪除、修改即可。界面如圖8:</p><p>  圖8:圖書類型管理圖</p><p><b>  主要程序代碼如下:</b></p><p>  proc

84、edure Tform_edit_booltype.BitBtn1Click(Sender: TObject);</p><p><b>  begin</b></p><p>  table1.Append;</p><p><b>  end;</b></p><p>  procedure T

85、form_edit_booltype.FormCreate(Sender: TObject);</p><p><b>  begin</b></p><p>  table1.CachedUpdates:=true;</p><p><b>  end;</b></p><p>  procedu

86、re Tform_edit_booltype.BitBtn2Click(Sender: TObject);</p><p><b>  begin</b></p><p>  table1.Delete;</p><p><b>  end;</b></p><p>  procedure Tfor

87、m_edit_booltype.BitBtn3Click(Sender: TObject);</p><p><b>  begin</b></p><p>  table1.AApplyUpdates;</p><p><b>  end;</b></p><p>  procedure Tfor

88、m_edit_booltype.BitBtn4Click(Sender: TObject);</p><p><b>  begin</b></p><p><b>  close;</b></p><p><b>  end;</b></p><p><b>  e

89、nd.</b></p><p>  3.3.5圖書借閱歸還窗體</p><p>  該窗體的作用是進(jìn)行圖書的借閱和歸還操作。在圖書館中每本書都有一個獨立的編號,這個編號是不會重復(fù)的。當(dāng)輸入編號后,系統(tǒng)會自動判斷圖的狀態(tài),是在書庫還是已經(jīng)外借。界面如圖9:</p><p>  圖9:圖書借閱歸還圖</p><p><b>

90、  主要程序代碼如下:</b></p><p>  procedure Tform_pass_book.FormCreate(Sender: TObject);</p><p><b>  begin</b></p><p>  edit1.MaxLength:=13;</p><p>  edit2.Max

91、Length:=8;</p><p>  edit2.Enabled:=false;</p><p>  bitbtn1.Enabled:=false;</p><p>  bitbtn2.Enabled:=false;</p><p><b>  end;</b></p><p>  proce

92、dure Tform_pass_book.Edit1Change(Sender: TObject);</p><p><b>  var</b></p><p>  S_sql:string;</p><p><b>  begin</b></p><p>  if length(edit1.Tex

93、t)=13 then</p><p><b>  begin</b></p><p>  query1.Close;</p><p>  query1.SQL.Clear;</p><p>  S_sql:='select 圖書信息表.圖書名稱,圖書類型信息表.類型名稱,圖書信息表.圖書編號,圖書信息表.圖書作者

94、,圖書信息表.出版社'+</p><p>  ' from 圖書信息表 inner join 圖書類型信息表 on (圖書信息表.類型號=圖書類型信息表.類型號)'+</p><p>  ' where 圖書編號='+''''+edit1.Text+ "";</p><p&g

95、t;  query1.SQL.Add(S_sql);</p><p>  query1.Open;</p><p>  if query1.RecordCount=1 then</p><p><b>  begin</b></p><p>  query3.Close;</p><p>  qu

96、ery3.SQL.Clear;</p><p>  S_sql:='select * from 借閱記錄信息表 where 圖書編號='+''''+edit1.Text+"";</p><p>  query3.SQL.Add(S_sql);</p><p>  query3.Open;</p

97、><p>  if query3.RecordCount=1 then</p><p><b>  begin</b></p><p>  query2.Close;</p><p>  query2.SQL.Clear;</p><p>  S_sql:= 'select 讀者庫.姓名,讀者

98、類型信息表.類型名稱, 讀者庫.性別,讀者庫.單位,讀者類型信息表.借期'+</p><p>  ' from "讀者庫.DB" 讀者庫 inner join "讀者類型信息表.DB" 讀者類型信息表 on (讀者庫.類型=讀者類型信息表.類型號)'+</p><p>  ' where 借書證號='+'

99、;'''+query3.fieldbyname('借書證號').AsString+"";</p><p>  query2.SQL.Add(S_sql);</p><p>  query2.Open;</p><p>  edit2.Text:=query3.fieldbyname('借書證號

100、9;).AsStringg;</p><p>  bitbtn1.Enabled:=false;</p><p>  bitbtn2.Enabled:=true;</p><p><b>  end</b></p><p><b>  else</b></p><p><

101、;b>  begin</b></p><p>  edit2.Enabled:=true;</p><p>  edit2.SetFocus;</p><p><b>  end</b></p><p><b>  end</b></p><p><b

102、>  end</b></p><p><b>  else</b></p><p><b>  begin</b></p><p>  edit2.Enabled:=false;</p><p>  bitbtn1.Enabled:=false;</p><p&

103、gt;  bitbtn2.Enabled:=false;</p><p>  dbedit1.Text:='';</p><p>  dbedit2.Text:='';</p><p>  dbedit3.Text:'';</p><p>  dbedit4.Text:='';&

104、lt;/p><p>  dbedit5.Text:='';</p><p><b>  end;</b></p><p>  if length(edit1.Text)<13 then</p><p><b>  begin</b></p><p>  

105、edit2.Text:='';</p><p>  dbedit6.Text:='';</p><p>  dbedit7.Text:='';</p><p>  dbedit8.Text:='';</p><p>  dbedit9.Text:='';</

106、p><p><b>  end;</b></p><p><b>  end;</b></p><p>  procedure Tform_pass_book.BitBtn1Click(Sender: TObject);</p><p><b>  var</b></p>

107、;<p>  S_sql:string;</p><p>  D_gh:Tdatetime;</p><p><b>  begin</b></p><p>  if length(edit1.Text)<>13 then</p><p>  showmessage('你輸入的圖書證號不

108、對!');</p><p>  dateseparator:='/';</p><p>  shortdateformat:='m/d/yyyy';</p><p>  query3.Close;</p><p>  query3.SQL.Clear;</p><p>  s_s

109、ql:=' select * from 借閱記錄信息表 where 借書證號='''+Edit2.text+'''and 歸還日期<'''+datetostr(date)+"";</p><p>  query3.SQL.Add(s_sql);</p><p>  query3.Ope

110、n;</p><p>  if query3.RecordCount<>0 then</p><p>  showmessage('該用戶有超期未還的書籍,不能節(jié)約其他書籍。')</p><p><b>  else</b></p><p><b>  begin</b>

111、</p><p>  query4.Close;</p><p>  query4.SQL.Clear;</p><p>  s_sql:='select 讀者類型信息表.借期 from 讀者庫 inner join "讀者類型信息表.DB" 讀者類型信息表 on (讀者庫.類型=讀者類型信息表.類型號) where 借書證號='

112、+''''+edit2.text+"";</p><p>  query4.SQL.Add(s_sql);</p><p>  query4.Open;</p><p>  D_gh:=date+query4.fieldbyname('借期').asinteger;</p><p

113、>  query3.Close;</p><p>  query3.SQL.Clear;</p><p>  S_sql:='insert into 借閱記錄信息表 Values('''+edit2.text+''','''+edit1.text+''',''

114、9;+datetostr(date)+''','''+datetostr(d_gh)+''',0)';</p><p>  query3.SQL.Add(S_sql);</p><p>  query3.ExecSQL;</p><p>  bitbtn1.Enabled:=false;

115、</p><p>  edit1.Text:='';</p><p>  showmessage('借書成功');</p><p><b>  end;</b></p><p><b>  end;</b></p><p>  procedur

116、e Tform_pass_book.BitBtn3Click(Sender: TObject);</p><p><b>  begin</b></p><p><b>  close;</b></p><p><b>  end;</b></p><p>  procedur

117、e Tform_pass_book.BitBtn2Click(Sender: TObject);</p><p><b>  var</b></p><p>  s_tsh,S_sql:string;</p><p>  I_days:Double;</p><p><b>  begin</b>&

118、lt;/p><p>  if query3.FieldByName('歸還日期').AsDateTime>Date then</p><p><b>  begin</b></p><p>  query4.Close;</p><p>  query4.SQL.Clear;</p>&l

119、t;p>  S_sql:='delete from 借閱記錄信息表 where 圖書編號='+''''+edit1.Text+"";</p><p>  query4.SQL.Add(S_sql);</p><p>  query4.ExecSQL;</p><p>  bitbtn2.Ena

120、bled:=false;</p><p>  edit1.Text:='';</p><p>  showmessage('歸還成功');</p><p><b>  end</b></p><p><b>  else</b></p><p>

121、;<b>  begin</b></p><p>  I_days:=date - query3.fieldbyname('歸還日期').AsDateTime;</p><p>  S_tsh:='該書超期'+floattostr(I_days)+'天,確定歸還該書?';</p><p>  if

122、 messagebox(0,pchar(s_tsh),'圖書管理系統(tǒng)',MB_OKCANCEL+MB_ICONQUESTION+MB_DEFBUTTON2)=IDok then</p><p><b>  begin</b></p><p>  query4.Close;</p><p>  query4.SQL.Clear;&

123、lt;/p><p>  S_sql:='delete from 借閱記錄信息表 where 圖書編號='+''''+edit1.Text+"";</p><p>  query4.SQL.Add(s_sql);</p><p>  query4.ExecSQL;</p><p>

124、  bitbtn2.Enabled:=false;</p><p><b>  end</b></p><p><b>  end</b></p><p><b>  end;</b></p><p>  procedure Tform_pass_book.Edit2Chang

125、e(Sender: TObject);</p><p><b>  var</b></p><p>  s_sql:string;</p><p><b>  begin</b></p><p>  if length(edit2.Text)=8 then</p><p>&

126、lt;b>  begin</b></p><p>  query2.Close;</p><p>  query2.SQL.Clear;</p><p>  s_sql:='select 讀者庫.姓名, 讀者類型信息表.類型名稱,讀者庫.性別,讀者庫.單位,讀者類型信息表.借期'+</p><p>  

127、9; from "讀者庫.DB" 讀者庫 inner join "讀者類型信息表.DB" 讀者類型信息表 on (讀者庫.類型=讀者類型信息表.類型號)'+</p><p>  ' where 借書證號='+''''+edit2.Text+"";</p><p>  quer

128、y2.SQL.Add(s_sql);</p><p>  query2.Open;</p><p>  if query2.RecordCount<>0 then</p><p>  bitbtn1.Enabled:=true</p><p><b>  else</b></p><p&g

129、t;  showmessage('你輸入的借書證號有誤!');</p><p><b>  end</b></p><p><b>  else</b></p><p><b>  begin</b></p><p>  dbedit6.Text:='&

130、#39;;</p><p>  dbedit7.Text:='';</p><p>  dbedit8.Text:='';</p><p>  dbedit9.Text:='';</p><p>  bitbtn1.Enabled:=false;</p><p><

131、b>  end;</b></p><p><b>  end;</b></p><p><b>  end.</b></p><p>  3.4數(shù)據(jù)更新窗體設(shè)計</p><p>  3.4.1圖書數(shù)據(jù)更新</p><p>  該窗體的作用是修改圖書信息。要修

132、改圖書首先要找到圖書,所以要完成圖書查詢操作。為了方便批量查詢圖書,設(shè)置若干個條件(圖書編號、名稱、作者、類型),這幾個條件之間是獨立的,也就是說可以設(shè)置這幾個條件中的任何一個或幾個。界面如圖11:</p><p>  圖11:圖書數(shù)據(jù)更新圖</p><p><b>  主要程序代碼如下:</b></p><p>  procedure TFo

133、rm_edit_book.FormCreate(Sender: TObject);</p><p><b>  begin</b></p><p>  query1.CachedUpdates:=true;</p><p>  query1.RequestLive:=true;</p><p>  combobox1.I

134、tems.Add(' ');</p><p>  table1.First;</p><p>  while not table1.Eof do</p><p><b>  begin</b></p><p>  combobox1.Items.Add(table1.fieldbyname('類型

135、名稱').AsString);</p><p>  table1.Next;</p><p><b>  end;</b></p><p>  dbedit8.Enabled:=false;</p><p>  table1.CachedUpdates:=true;</p><p><

136、;b>  end;</b></p><p>  procedure TForm_edit_book.BitBtn1Click(Sender: TObject);</p><p><b>  var</b></p><p>  S_sql:string;</p><p><b>  begin&

137、lt;/b></p><p>  if length(edit1.Text)<>13 then</p><p>  showmessage('你輸入的圖書編號有誤,請輸入13位圖書編號!');</p><p>  query1.Close;</p><p>  query1.SQL.Clear;</p&

138、gt;<p>  s_sql:='select 圖書編號,類型號,圖書名稱,圖書作者,出版社,單價,開本,進(jìn)庫日期 from 圖書信息表 where 1=1';</p><p>  if not checkbox1.Checked then</p><p><b>  begin</b></p><p>  if

溫馨提示

  • 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)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論