庫(kù)存管理系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn)畢業(yè)論文_第1頁(yè)
已閱讀1頁(yè),還剩62頁(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、<p>  編號(hào):__________________</p><p><b>  畢業(yè)論文</b></p><p>  題目:庫(kù)存管理系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn)</p><p>  畢業(yè)設(shè)計(jì)(論文)任務(wù)書(shū)</p><p>  系 別:______________ 班 級(jí):______________<

2、;/p><p>  姓 名:______________ 指導(dǎo)教師:______________</p><p><b>  題目:</b></p><p>  設(shè)計(jì)(論文)要求(包括主要指標(biāo)):</p><p><b>  參考文獻(xiàn): </b></p><p>  設(shè)

3、計(jì)報(bào)告(論文)提綱、目錄:</p><p><b>  指導(dǎo)教師簽字:</b></p><p><b>  年 月 日</b></p><p>  中國(guó)管理軟件學(xué)院教務(wù)處</p><p><b>  本 人 聲 明</b></p><p>  本

4、人聲明所呈交的論文是我個(gè)人在導(dǎo)師指導(dǎo)下進(jìn)行的研究工作及取得的研究成果。盡我所知,除了文中特別加以標(biāo)注和致謝的地方外,論文中不包含其他人已經(jīng)發(fā)表或撰寫(xiě)過(guò)的研究成果,也不包含為獲得中國(guó)管理軟件學(xué)院或其它教育機(jī)構(gòu)的學(xué)位或證書(shū)而使用過(guò)的材料。與我一同工作的同志對(duì)本工作組做的任何貢獻(xiàn)均已在論文中作了明確的說(shuō)明并表示了謝意。</p><p>  作者簽名: </p><p&

5、gt;<b>  年 月 日</b></p><p><b>  摘 要</b></p><p>  隨著計(jì)算機(jī)技術(shù)的迅速發(fā)展,在“信息時(shí)代”的21世紀(jì),計(jì)算機(jī)在生產(chǎn)、經(jīng)營(yíng)、管理等領(lǐng)域中的應(yīng)用越來(lái)越廣泛。</p><p>  本系統(tǒng)是圍繞KONCOR市場(chǎng)營(yíng)銷(xiāo)有限責(zé)任公司的CANON市場(chǎng)部的業(yè)務(wù)進(jìn)行調(diào)研,針對(duì)企業(yè)的

6、業(yè)務(wù)現(xiàn)狀采用結(jié)構(gòu)化的開(kāi)發(fā)方法進(jìn)行系統(tǒng)分析、系統(tǒng)設(shè)計(jì)和系統(tǒng)實(shí)施。結(jié)構(gòu)化系統(tǒng)開(kāi)發(fā)方法用系統(tǒng)工程的思想和工程化的方法,按用戶至上的原則、結(jié)構(gòu)化、模塊化、自頂向下地對(duì)系統(tǒng)進(jìn)行開(kāi)發(fā)。</p><p>  系統(tǒng)編寫(xiě)采用Visual C+++6.0為前臺(tái)開(kāi)發(fā)工具,SQL Server 2000為后臺(tái)數(shù)據(jù)庫(kù)開(kāi)發(fā)工具。系統(tǒng)包括物資采購(gòu)管理、庫(kù)存管理和供應(yīng)商管理等模塊,系統(tǒng)主要實(shí)現(xiàn)的功能有信息錄入,信息查詢,信息修改,以及統(tǒng)計(jì)等。系

7、統(tǒng)的運(yùn)用,能提高工作效率,對(duì)物資供應(yīng)管理提供了有效的工具。</p><p>  關(guān)鍵詞:管理信息系統(tǒng);結(jié)構(gòu)化分析方法;庫(kù)存管理系統(tǒng);VC++;SQL Server 2000</p><p><b>  Abstract</b></p><p>  With the rapid development of the technology of t

8、he computer, the 21st century in " information age ", computer's application in the fields , such as producing , managing , management ,etc. is more and more extensive. This system is investigated around th

9、e business of KONCOR Co., Ltd.adopt the structurization development approach to carry on network analysis , design systematically and implement systematically to the business current situation of enterprises. The systema

10、tic development approach </p><p>  Key words:Design; Management Information System; Strutured System Development Methodologies; Inventory ManagementSystem; VC++ 6.0;SQL Server 2000</p><p><b&

11、gt;  .</b></p><p><b>  目 錄</b></p><p>  AbstractIII</p><p><b>  1 緒論1</b></p><p>  1.1 倉(cāng)庫(kù)管理系統(tǒng)開(kāi)發(fā)環(huán)境簡(jiǎn)介1</p><p>  1.2 中文Vis

12、ual C++ 6.0簡(jiǎn)介2</p><p>  1.3 SQL SERVER 2000簡(jiǎn)介2</p><p>  2 系統(tǒng)可行性分析4</p><p>  3 系統(tǒng)總體設(shè)計(jì)5</p><p>  3.1 系統(tǒng)目標(biāo)設(shè)計(jì)5</p><p>  3.3 系統(tǒng)功能需求分析6</p><

13、;p>  3.4系統(tǒng)功能模塊設(shè)計(jì)6</p><p>  4 數(shù)據(jù)庫(kù)設(shè)計(jì)7</p><p>  4.1 數(shù)據(jù)庫(kù)需求分析7</p><p>  4.2數(shù)據(jù)庫(kù)邏輯結(jié)構(gòu)設(shè)計(jì)7</p><p>  4.2.1管理員基本信息表8</p><p>  4.2.2機(jī)型信息表8</p><p&g

14、t;  4.2.3查詢賬戶信息表9</p><p>  4.2.4外借信息表9</p><p>  4.2.5罰單信息表10</p><p>  4.3 創(chuàng)建表的腳本文件10</p><p>  5 系統(tǒng)主窗體設(shè)計(jì)13</p><p>  5.1 創(chuàng)建工程項(xiàng)目—倉(cāng)庫(kù)管理系統(tǒng)13</p>&l

15、t;p>  5.2 創(chuàng)建系統(tǒng)主窗體13</p><p>  5.2.1倉(cāng)庫(kù)管理14</p><p>  5.2.2查詢賬戶管理14</p><p>  5.2.3系統(tǒng)管理15</p><p>  5.3 連接數(shù)據(jù)庫(kù)15</p><p>  5.4 工程模塊設(shè)計(jì)17</p><p&g

16、t;  5.4.1登錄模塊設(shè)計(jì)17</p><p>  5.4.2倉(cāng)庫(kù)管理模塊設(shè)計(jì)18</p><p><b>  致 謝51</b></p><p><b>  參考文獻(xiàn)52</b></p><p><b>  1 緒論</b></p><p&

17、gt;  隨著經(jīng)濟(jì)的快速發(fā)展,大眾消費(fèi)水平以及生活水平的提高,使得數(shù)碼產(chǎn)品蓬勃發(fā)展,這給許多數(shù)碼廠商帶來(lái)了新的生機(jī)。同時(shí)技術(shù)的革新和國(guó)外企業(yè)進(jìn)入市場(chǎng),數(shù)碼生產(chǎn)企業(yè)面臨著越來(lái)越激烈的競(jìng)爭(zhēng),為了獲得更多的利潤(rùn),降低生產(chǎn)成本,要求數(shù)碼生產(chǎn)企業(yè)不斷改善企業(yè)供應(yīng)管理的各個(gè)環(huán)節(jié),迅速適應(yīng)市場(chǎng)的變化。  長(zhǎng)期以來(lái),KONCOR有限公司在供應(yīng)管理工作中的信息管理是大量采用人工的方式,要付出大量人力,填寫(xiě)各種表格、憑證、賬冊(cè)、卡片和文件。這種

18、手工操作的管理方式,不僅浪費(fèi)人力,而且存在許多缺點(diǎn):(1)處理速度慢,影響信息及時(shí)性。(2)易出現(xiàn)錯(cuò)誤,影響信息精確性。(3)不便于查詢。(4)缺乏綜合性,不能起控制作用。由于這些缺點(diǎn),大大降低了信息的利用價(jià)值,顯然越來(lái)越不適應(yīng)現(xiàn)代物資管理工作的需要。因此,發(fā)展以計(jì)算機(jī)為基礎(chǔ)的供應(yīng)管理信息系統(tǒng)已是十分迫切和必要的了。  我在對(duì)KONCOR有限公司供應(yīng)部進(jìn)行實(shí)習(xí)調(diào)研之后,結(jié)合自己的計(jì)算機(jī)知識(shí)和企業(yè)的工作實(shí)際,本著“以人為本”的

19、設(shè)計(jì)理念,分析設(shè)計(jì)了本系統(tǒng)。本系統(tǒng)針對(duì)供應(yīng)部的采購(gòu)管理、庫(kù)存管理以及供應(yīng)商管理等進(jìn)行了模塊的劃分,采取了結(jié)構(gòu)化的分析方法進(jìn)行分析和設(shè)計(jì),運(yùn)用先進(jìn)的開(kāi)發(fā)</p><p>  1.1 倉(cāng)庫(kù)管理系統(tǒng)開(kāi)發(fā)環(huán)境簡(jiǎn)介</p><p>  本倉(cāng)庫(kù)管理系統(tǒng)是在以Visual C++ 6.0為編程語(yǔ)言,以SQL server 2000作為后臺(tái)數(shù)據(jù)庫(kù)而開(kāi)發(fā)的一個(gè)數(shù)據(jù)庫(kù)管理系統(tǒng)。下面簡(jiǎn)要介紹一下中文Visual

20、 C++ 6.0和SQL server 2000。</p><p>  1.2 中文Visual C++ 6.0簡(jiǎn)介</p><p>  Visual C++ 6.0,簡(jiǎn)稱(chēng)VC或者VC6.0,是微軟推出的一款C++編譯器,將“高級(jí)語(yǔ)言”翻譯為“機(jī)器語(yǔ)言(低級(jí)語(yǔ)言)”的程序。Visual C++是一個(gè)功能強(qiáng)大的可視化軟件開(kāi)發(fā)工具。自1993年Microsoft公司推出Visual C++1

21、.0后,隨著其新版本的不斷問(wèn)世,Visual C++已成為專(zhuān)業(yè)程序員進(jìn)行軟件開(kāi)發(fā)的首選工具。雖然微軟公司推出了 Visual C++.NET(Visual C++7.0),但它的應(yīng)用的很大的局限性,只適用于Windows 2000、Windows XP和Windows NT4.0。所以實(shí)際中,更多的是以Visual C++6.0為平臺(tái)。Visual C++6.0不僅是一個(gè)C++ 編譯器,而且是一個(gè)基于Windows操作系統(tǒng)的可

22、視化集成開(kāi)發(fā)環(huán)境(integrated development environment,IDE)。Visual C++6.0由許多組件組成,包括編輯器、調(diào)試器以及程序向?qū)ppWizard、類(lèi)向?qū)lass Wizard等開(kāi)發(fā)工具。 這些組件通過(guò)一個(gè)名為Developer Studio的組件集成為和諧的開(kāi)發(fā)環(huán)境。</p><p>  1.3 SQL SERVER 2000簡(jiǎn)介</p><p&

23、gt;  SQL Server 2000 是Microsoft 公司推出的SQL Server 數(shù)據(jù)庫(kù)管理系統(tǒng)的一個(gè)版本。該版本繼承了SQL Server 7.0 版本的優(yōu)點(diǎn)同時(shí)又比它增加了許多更先進(jìn)的功能,具有使用方便,可伸縮性好與相關(guān)軟件集成程度高等優(yōu)點(diǎn),可跨越從運(yùn)行Microsoft Windows 98 的膝上型電腦到運(yùn)行Microsoft Windows 2000 的大型多處理器的服務(wù)器等多種平臺(tái)使用。</p>

24、<p>  SQL Server 2000 的特性Microsoft SQL Server 2000 的特性包括:</p><p>  1.Internet 集成。SQL Server 2000 數(shù)據(jù)庫(kù)引擎提供完整的XML 支持。它還具有構(gòu)成最大的Web 站點(diǎn)的數(shù)據(jù)存儲(chǔ)組件所需的可伸縮性、可用性和安全功能。SQL Server 2000 程序設(shè)計(jì)模型與 Windows DNA 構(gòu)架集成,用以開(kāi)發(fā) Web

25、 應(yīng)用程序,并且SQL Server 2000 支持 English Query 和 Microsoft 搜索服務(wù)等功能,在Web 應(yīng)用程序中包含了用戶友好的查詢和強(qiáng)大的搜索功能。</p><p>  2.可伸縮性和可用性。同一個(gè)數(shù)據(jù)庫(kù)引擎可以在不同的平臺(tái)上使用,從運(yùn)行 Microsoft Windows 98 的便攜式電腦,到運(yùn)行 Microsoft Windows 2000 數(shù)據(jù)中心版的大型多處理器服務(wù)器。

26、SQL Server 2000 企業(yè)版支持聯(lián)合服務(wù)器、索引視圖和大型內(nèi)存支持等功能,使其得以升級(jí)到最大 Web 站點(diǎn)所需的性能級(jí)別。</p><p>  3.企業(yè)級(jí)數(shù)據(jù)庫(kù)功能。SQL Server 2000 關(guān)系數(shù)據(jù)庫(kù)引擎支持當(dāng)今苛刻的數(shù)據(jù)處理環(huán)境所需的功能。數(shù)據(jù)庫(kù)引擎充分保護(hù)數(shù)據(jù)完整性,同時(shí)將管理上千個(gè)并發(fā)修改數(shù)據(jù)庫(kù)的用戶的開(kāi)銷(xiāo)減到最小。SQL Server 2000 分布式查詢使您得以引用來(lái)自不同數(shù)據(jù)源的數(shù)據(jù)

27、,就好象這些數(shù)據(jù)是 SQL Server 2000 數(shù)據(jù)庫(kù)的一部分,同時(shí)分布式事務(wù)支持充分保護(hù)任何分布式數(shù)據(jù)更新的完整性。復(fù)制同樣使您得以維護(hù)多個(gè)數(shù)據(jù)復(fù)本,同時(shí)確保單獨(dú)的數(shù)據(jù)復(fù)本保持同步。可將一組數(shù)據(jù)復(fù)制到多個(gè)移動(dòng)的脫接用戶,使這些用戶自主地工作,然后將他們所做的修改合并回發(fā)布服務(wù)器。</p><p>  4.易于安裝、部署和使用。 SQL Server 2000 中包括一系列管理和開(kāi)發(fā)工具,這些工具可改進(jìn)在多個(gè)

28、站點(diǎn)上安裝、部署、管理和使用 SQL Server 的過(guò)程。SQL Server 2000 還支持基于標(biāo)準(zhǔn)的、與 Windows DNA 集成的程序設(shè)計(jì)模型,使 SQL Server 數(shù)據(jù)庫(kù)和數(shù)據(jù)倉(cāng)庫(kù)的使用成為生成強(qiáng)大的可伸縮系統(tǒng)的無(wú)縫部分。這些功能使您得以快速交付 SQL Server 應(yīng)用程序,使客戶只需最少的安裝和管理開(kāi)銷(xiāo)即可實(shí)現(xiàn)這些應(yīng)用程序。</p><p>  數(shù)據(jù)倉(cāng)庫(kù)。 SQL Server 2000

29、 中包括析取和分析匯總數(shù)據(jù)以進(jìn)行聯(lián)機(jī)分析處理 (OLAP) 的工具。</p><p>  SQL Server 2000 其主要特點(diǎn)如下:</p><p>  (1)高性能設(shè)計(jì),可充分利用WindowsNT的優(yōu)勢(shì)。</p><p>  (2)系統(tǒng)管理先進(jìn),支持Windows圖形化管理工具,支持本地和遠(yuǎn)程的系統(tǒng)管理和配置。</p><p>  

30、(3)強(qiáng)壯的事務(wù)處理功能,采用各種方法保證數(shù)據(jù)的完整性。</p><p>  (4)支持對(duì)稱(chēng)多處理器結(jié)構(gòu)、存儲(chǔ)過(guò)程、ODBC,并具有自主的SQL語(yǔ)言。 SQLServer以其內(nèi)置的數(shù)據(jù)復(fù)制功能、強(qiáng)大的管理工具、與Internet的緊密集成和開(kāi)放的系統(tǒng)結(jié)構(gòu)為廣大的用戶、開(kāi)發(fā)人員和系統(tǒng)集成商提供了一個(gè)出眾的數(shù)據(jù)庫(kù)平臺(tái)。ver 中還包括一些工具,可用來(lái)直觀地設(shè)計(jì)數(shù)據(jù)庫(kù)并通過(guò) English Query 來(lái)分析數(shù)據(jù)。&l

31、t;/p><p>  本系統(tǒng)就是在以SQL2000作為后臺(tái)數(shù)據(jù)庫(kù),以VC++為編程語(yǔ)言為中小型企業(yè)管理倉(cāng)庫(kù)而開(kāi)發(fā)的一個(gè)數(shù)據(jù)庫(kù)管理系統(tǒng)</p><p>  2 系統(tǒng)可行性分析</p><p>  可行性分析的任務(wù),并不是所有問(wèn)題都有簡(jiǎn)單明顯的解決辦法,事實(shí)上,許多問(wèn)題不可能在預(yù)定的系統(tǒng)規(guī)模之內(nèi)解決。如果問(wèn)題沒(méi)有可行的解,那么花費(fèi)這項(xiàng)開(kāi)發(fā)工程上的任何時(shí)間、資源、人力和經(jīng)費(fèi)

32、都是無(wú)謂的浪費(fèi)。</p><p>  可行性研究的目的就是用最小的代價(jià)在盡可能短的時(shí)間內(nèi)確定問(wèn)題是否能夠解決。必須記住,可行性研究的目的不是解決問(wèn)題,而是確定問(wèn)題是否值得去解。怎樣達(dá)到這個(gè)目的呢?當(dāng)然不能靠主觀猜想,而只能靠客觀分析。必須分析幾種主要的可能解法的利弊,從而判斷原定的系統(tǒng)目標(biāo)和規(guī)模是否現(xiàn)實(shí),系統(tǒng)完成后所能帶來(lái)的效益是否大到值得投資開(kāi)發(fā)這個(gè)系統(tǒng)的程度。</p><p>  因此

33、,可行性研究實(shí)質(zhì)上是要進(jìn)行一次大大壓縮簡(jiǎn)化了的系統(tǒng)分析和設(shè)計(jì)的過(guò)程,也就是在較高層次上以較抽象的方式進(jìn)行的系統(tǒng)分析和設(shè)計(jì)的過(guò)程。所以從以上的分析原則來(lái)看,我所設(shè)計(jì)的倉(cāng)庫(kù)信息管理系統(tǒng)是一個(gè)規(guī)模不太大的系統(tǒng),但是目標(biāo)明確,清晰的描述了對(duì)目標(biāo)系統(tǒng)的一切限制和約束。本系統(tǒng)幾乎在所有的企業(yè)、公司使用,當(dāng)然它需要進(jìn)一步的完善和更新。在使用過(guò)程中,要看它能不能帶來(lái)效益,畢竟在現(xiàn)今社會(huì)效率是第一位的。從現(xiàn)實(shí)看,這還是有一定的實(shí)用價(jià)值的,從另一個(gè)角度看,

34、現(xiàn)實(shí)社會(huì)發(fā)展飛速,尊重科技勢(shì)在必行,因此這也是開(kāi)發(fā)本系統(tǒng)的一個(gè)非常重要的原因。21世紀(jì)是計(jì)算機(jī)的時(shí)代,它必然取代一部分人的工作,高科技的監(jiān)控系統(tǒng)進(jìn)入社會(huì)生活的方方面面是發(fā)展的趨勢(shì)。</p><p>  本設(shè)計(jì)從一下三個(gè)方面進(jìn)行可行性研究:</p><p>  1. 技術(shù)可行性。本設(shè)計(jì)“倉(cāng)庫(kù)管理系統(tǒng)”是為企業(yè)倉(cāng)庫(kù)管理人員開(kāi)發(fā)的。鑒于本人在上學(xué)期數(shù)據(jù)庫(kù)課程設(shè)計(jì)中已用Visual C++6.0+

35、SQL 2000開(kāi)發(fā)過(guò)圖書(shū)管管理信息系統(tǒng),而且通過(guò)三個(gè)月畢業(yè)實(shí)習(xí)中的學(xué)習(xí)和實(shí)踐,對(duì)開(kāi)發(fā)管理信息系統(tǒng)又有了新的認(rèn)識(shí)和提高,使自己在開(kāi)發(fā)管理信息系統(tǒng)方面的技術(shù)更加成熟。由于本設(shè)計(jì)最重要體現(xiàn)的是實(shí)用性,所以,通過(guò)大量的社會(huì)調(diào)查和分析,結(jié)合自己現(xiàn)有的技術(shù)水平加上導(dǎo)師的指導(dǎo),還是能按期完成本畢業(yè)設(shè)計(jì)。</p><p>  2. 經(jīng)濟(jì)可行性。成本方面:由于本畢業(yè)設(shè)計(jì)屬于計(jì)算機(jī)科學(xué)(本科)教學(xué)的最后一個(gè)環(huán)節(jié),所以人力消耗免費(fèi),

36、資源學(xué)校提供,指導(dǎo)老師義務(wù)指導(dǎo)。所以成本計(jì)算只需計(jì)算開(kāi)發(fā)期間開(kāi)發(fā)者的生活消費(fèi),學(xué)校資源的消耗,所以開(kāi)發(fā)本軟件的成本是非常低的。效益方面:為企業(yè)開(kāi)發(fā)一個(gè)完整、合理的倉(cāng)庫(kù)管理系統(tǒng),可大大節(jié)余人力,以前需要多人干的工作,使用本系統(tǒng)只需一個(gè)人或幾個(gè)人就能完成,且工作量和勞動(dòng)強(qiáng)度大大降低。所以開(kāi)發(fā)本軟件可以為社會(huì)帶來(lái)很好的經(jīng)濟(jì)效益。</p><p>  從以上分析看開(kāi)發(fā)本軟件在經(jīng)濟(jì)上是可行的。</p><

37、;p>  3. 操作可行性。本軟件是為企業(yè)倉(cāng)庫(kù)的管理者開(kāi)發(fā)的,所有本軟件的用戶對(duì)象是企業(yè)倉(cāng)庫(kù)的工作人員,由于本軟件要設(shè)計(jì)成友好的界面,寫(xiě)出詳細(xì)的使用說(shuō)明,用戶只需懂得簡(jiǎn)單的計(jì)算機(jī)操作知識(shí),就能自由應(yīng)用本軟件。</p><p>  所以從以上幾個(gè)方面的分析來(lái)看,開(kāi)發(fā)本軟件是完全可行的。</p><p><b>  3 系統(tǒng)總體設(shè)計(jì)</b></p>

38、<p>  3.1 系統(tǒng)目標(biāo)設(shè)計(jì)</p><p>  系統(tǒng)開(kāi)發(fā)的總體任務(wù)是實(shí)現(xiàn)企業(yè)產(chǎn)品管理的系統(tǒng)化、規(guī)范化和自動(dòng)化,從而達(dá)到提高企業(yè)管理效率的目的。</p><p>  3.2 開(kāi)發(fā)設(shè)計(jì)思想</p><p>  倉(cāng)庫(kù)管理主要是企業(yè)各種商品的管理。企業(yè)各個(gè)部門(mén)根據(jù)需要提出產(chǎn)品請(qǐng)求,計(jì)劃員根據(jù)整個(gè)企業(yè)的需求開(kāi)出產(chǎn)品出庫(kù)單,倉(cāng)庫(kù)管理人員根據(jù)出庫(kù)單核對(duì)發(fā)放產(chǎn)品

39、。根據(jù)需要按照月進(jìn)行統(tǒng)計(jì)分析,產(chǎn)生相應(yīng)報(bào)表。</p><p>  倉(cāng)庫(kù)管理的特點(diǎn)是信息處理量比較大,所管理的產(chǎn)品種類(lèi)繁多,而且由于入庫(kù)單、出庫(kù)單、盤(pán)點(diǎn)單等單據(jù)發(fā)生量特別大,關(guān)聯(lián)信息多,查詢和統(tǒng)計(jì)的方式各不相同。因此在管理上實(shí)現(xiàn)起來(lái)有一定的困難。在管理的過(guò)程中經(jīng)常會(huì)出現(xiàn)信息的重復(fù)傳遞;單據(jù)、報(bào)表種類(lèi)繁多,各個(gè)部門(mén)管理規(guī)格不統(tǒng)一等問(wèn)題。</p><p>  在本系統(tǒng)的設(shè)計(jì)過(guò)程中,為了克服這些困

40、難,滿足計(jì)算機(jī)管理工作的需要,我們采取了下面的一些原則。</p><p>  ●刪除不必要的管理冗余,實(shí)現(xiàn)管理規(guī)范化、科學(xué)化。</p><p>  ●程序代碼標(biāo)準(zhǔn)化,軟件統(tǒng)一化,確保軟件的可維護(hù)性和實(shí)用性。</p><p>  ●界面盡量簡(jiǎn)單化,做到實(shí)用、方便,盡量滿足企業(yè)中不同層次員工的需要。</p><p>  3.3 系統(tǒng)功能需求分析

41、</p><p>  系統(tǒng)開(kāi)發(fā)的總體任務(wù)是實(shí)現(xiàn)各種信息的系統(tǒng)化、規(guī)范化和自動(dòng)化。系統(tǒng)功能分析是在系統(tǒng)開(kāi)發(fā)的總體任務(wù)的基礎(chǔ)上完成。本倉(cāng)庫(kù)管理系統(tǒng)需要完成功能主要有:</p><p>  ●身份驗(yàn)證:提供系統(tǒng)的訪問(wèn)控制功能。</p><p>  ●倉(cāng)庫(kù)管理:包括樣機(jī)登記、外借、歸還、樣機(jī)掛失、樣機(jī)信息查詢、等功能。</p><p>  ●查詢賬戶

42、管理:提供辦理查詢賬戶、查詢賬戶信息查詢、查詢賬戶掛失。</p><p>  ●系統(tǒng)管理:包括添加帳號(hào)、修改密碼和退出系統(tǒng)能功能</p><p>  3.4系統(tǒng)功能模塊設(shè)計(jì)</p><p>  通過(guò)對(duì)倉(cāng)庫(kù)管理系統(tǒng)的功能分析,可以定義出系統(tǒng)的功能模塊圖,如圖3-1所示。 </p><p>  圖3-1 系統(tǒng)功能模塊圖。</p>&

43、lt;p><b>  4 數(shù)據(jù)庫(kù)設(shè)計(jì)</b></p><p>  4.1 數(shù)據(jù)庫(kù)需求分析</p><p>  系統(tǒng)的需求具體體現(xiàn)在對(duì)各種信息的保存、修改和查詢等方面。因此,一個(gè)滿足系統(tǒng)要求</p><p>  的數(shù)據(jù)庫(kù)必須充分照顧到對(duì)各種信息的輸入輸出,以免遺漏導(dǎo)致開(kāi)發(fā)時(shí)返工。</p><p>  通過(guò)對(duì)系統(tǒng)功

44、能的分析,圖書(shū)館管理系統(tǒng)需要包含以下數(shù)據(jù)庫(kù)信息。</p><p> ?。芾韱T基本信息:包括成員ID、密碼等。</p><p> ?。畽C(jī)型信息:包括機(jī)型ID、機(jī)型名稱(chēng)、產(chǎn)地、進(jìn)口商、單價(jià)、入庫(kù)時(shí)間、總量、現(xiàn)</p><p><b>  存總量。</b></p><p> ?。饨铏C(jī)器信息:包括外借機(jī)器ID、查詢賬戶信息、

45、查詢賬戶所有人、外借日期。</p><p> ?。樵冑~戶信息:包括查詢賬戶賬號(hào)、姓名、性別、出生日期、家庭住址、身份證號(hào)碼、</p><p>  電話號(hào)碼、現(xiàn)借機(jī)總數(shù)。</p><p> ?。P金信息:包括罰金號(hào)、查詢賬戶賬號(hào)、機(jī)器ID、外借時(shí)間、返還時(shí)間、罰金。</p><p>  圖4-1 倉(cāng)庫(kù)管理系統(tǒng)數(shù)據(jù)流程圖</p>

46、<p>  4.2數(shù)據(jù)庫(kù)邏輯結(jié)構(gòu)設(shè)計(jì)</p><p>  數(shù)據(jù)庫(kù)邏輯結(jié)構(gòu)的設(shè)計(jì)有兩個(gè)目標(biāo),一是對(duì)需求分析中的實(shí)體建立對(duì)應(yīng)的表:一是將實(shí)體之間的聯(lián)系映射到表之間的關(guān)系上,具體來(lái)說(shuō)就是設(shè)置表的主鍵和外鍵。在這個(gè)過(guò)程中通常采用E-R圖進(jìn)行分析,如圖4-2所示,首先對(duì)局部視圖進(jìn)行分析設(shè)計(jì),然后再實(shí)現(xiàn)視圖生成,注意要盡量消除沖突和冗余。在這里直接給出E-R圖。</p><p>  4.2.

47、1管理員基本信息表</p><p>  管理員基本信息表(Admin_Info)含了倉(cāng)庫(kù)管理員的基本信息,其結(jié)構(gòu)如表4-1所示。</p><p>  4.2.2機(jī)型信息表</p><p>  機(jī)型信息表(Book_Info)中含了倉(cāng)庫(kù)里所有機(jī)型的基本信息,用來(lái)方便職員查詢和借調(diào),其結(jié)構(gòu)如表4-2所示。</p><p>  圖4-2 倉(cāng)庫(kù)管理系

48、統(tǒng)的數(shù)據(jù)庫(kù)模型</p><p>  表4-1管理員基本信息表</p><p><b>  表4-2機(jī)型信息表</b></p><p>  4.2.3查詢賬戶信息表</p><p>  查詢賬戶信息表(Proof_info)包含了所有職員的查詢賬戶信息,用來(lái)方便職員外借和管理員管</p><p> 

49、 理,其結(jié)構(gòu)如表4-3所示。</p><p>  表4-3查詢賬戶信息表</p><p>  4.2.4外借信息表</p><p>  外借信息表(Borrow_info)包含了所有樣機(jī)外借的信息,用來(lái)方便管理員管理倉(cāng)庫(kù)的樣機(jī)出借情況,其結(jié)構(gòu)如表所示。</p><p><b>  表4-4外借信息表</b></p

50、><p>  4.2.5罰單信息表</p><p>  罰單信息表(Punish_info)包含了所有員工的罰金信息,用來(lái)方便管理員管理樣機(jī)外借超時(shí)情況,其結(jié)構(gòu)如表4-5所示。</p><p><b>  表4-5罰單信息表</b></p><p>  4.3 創(chuàng)建表的腳本文件</p><p>  數(shù)

51、據(jù)庫(kù)部分可以通過(guò)SQL Server企業(yè)管理器來(lái)創(chuàng)建,也可以通過(guò)Transact-SQL 語(yǔ)句來(lái)創(chuàng)建,對(duì)應(yīng)的SQL語(yǔ)句如下。</p><p>  初始化設(shè)置完畢后,通過(guò)該用戶可以登錄系統(tǒng)。本實(shí)例中使用的用戶名和密碼均為lib</p><p>  另外,在查詢分析器中執(zhí)行這些SQL語(yǔ)句時(shí),首先應(yīng)將當(dāng)前操作數(shù)據(jù)庫(kù)設(shè)置為L(zhǎng)ibrary。否則,所有表都將創(chuàng)建到Master數(shù)據(jù)庫(kù)中。操作的最終結(jié)果如

52、圖4-3。</p><p>  圖4-3Library數(shù)據(jù)庫(kù)在SQL Server 企業(yè)管理器視圖中</p><p>  5 系統(tǒng)主窗體設(shè)計(jì)</p><p>  5.1 創(chuàng)建工程項(xiàng)目—倉(cāng)庫(kù)管理系統(tǒng)</p><p>  打開(kāi)Visual C++ 后,單擊文件 -> 新建 菜單,在工程模板中選擇MFCAppWizard(exe)將出現(xiàn)一個(gè)

53、應(yīng)用程序向?qū)Вx擇基本對(duì)話框,不使用MFC動(dòng)態(tài)庫(kù),其它屬性都是缺省設(shè)置,將這個(gè)工程項(xiàng)目命名為倉(cāng)庫(kù)管理系統(tǒng),如圖5-1。</p><p>  圖5-1創(chuàng)建項(xiàng)目頁(yè)面</p><p>  5.2 創(chuàng)建系統(tǒng)主窗體</p><p>  在資源編輯器中設(shè)計(jì)主對(duì)話框界面,布局如圖5-1所示。其中包括了倉(cāng)庫(kù)管理、查詢賬戶管理和系統(tǒng)管理3個(gè)部分。</p><p&g

54、t;  主窗體界面設(shè)計(jì)如圖5-2所示。</p><p><b>  圖5-2系統(tǒng)主頁(yè)面</b></p><p><b>  5.2.1倉(cāng)庫(kù)管理</b></p><p>  倉(cāng)庫(kù)管理的控件類(lèi)型、ID及說(shuō)明如表5-1所示。</p><p>  表5-1 倉(cāng)庫(kù)管理控件列表</p><p

55、>  5.2.2查詢賬戶管理</p><p>  查詢賬戶管理的控件類(lèi)型、ID及說(shuō)明如表5-2所示。</p><p>  表5-2查詢賬戶管理控件列表</p><p><b>  5.2.3系統(tǒng)管理</b></p><p>  系統(tǒng)管理的控件類(lèi)型、ID及說(shuō)明如表5-3所示。</p><p>

56、  表5-3系統(tǒng)管理控件表</p><p>  主對(duì)話框類(lèi)名稱(chēng)為CLibDBSDlg,資源ID為IDD_LIBDBS,對(duì)話框名稱(chēng)為“倉(cāng)庫(kù)管理系統(tǒng)”。主界面由3個(gè)下拉列表框控件組成,分為3個(gè)主要的功能區(qū):倉(cāng)庫(kù)管理、查詢賬戶管理和系統(tǒng)管理。下一節(jié)分別講述這三部分的功能以及實(shí)現(xiàn)過(guò)程。</p><p><b>  5.3 連接數(shù)據(jù)庫(kù)</b></p><p&

57、gt;  當(dāng)系統(tǒng)啟動(dòng)之后,就要連接數(shù)據(jù)庫(kù)了,需要3個(gè)參數(shù):ODBC數(shù)據(jù)源名稱(chēng)、數(shù)據(jù)庫(kù)用戶名稱(chēng)、數(shù)據(jù)庫(kù)用戶密碼。</p><p>  登錄到主界面之前,首先調(diào)用管理員登錄模塊。從數(shù)據(jù)庫(kù)中讀入Admin_Info表的內(nèi)客,判斷用戶輸入的用戶名和密碼是否正確。主要代碼如下:</p><p>  用戶名和密碼都正確,才能進(jìn)入系統(tǒng)。</p><p>  5.4 工程模塊設(shè)計(jì)&

58、lt;/p><p>  工程的框架設(shè)計(jì)完成之后,就可以根據(jù)需求實(shí)現(xiàn)各個(gè)模塊。在本系統(tǒng)中需要編碼實(shí)現(xiàn)的主要有登錄、樣機(jī)管理、查詢賬戶管理、系統(tǒng)與其他模塊管理4個(gè)模塊。</p><p>  5.4.1登錄模塊設(shè)計(jì)</p><p>  在進(jìn)入主對(duì)話框之前,首先調(diào)用登錄對(duì)話框,可以創(chuàng)建一個(gè)對(duì)話框,對(duì)話框包含了數(shù)據(jù)源的名稱(chēng)、用戶名和密碼 3個(gè)部分,界面如圖 所示。添加的對(duì)話框類(lèi)名

59、稱(chēng)為 CLibraryDlg,資源ID為IDD_LIBRARY_DIALOG,對(duì)話框名稱(chēng)為“倉(cāng)庫(kù)管理系統(tǒng)”。</p><p>  “倉(cāng)庫(kù)管理系統(tǒng)”對(duì)話框中的控件類(lèi)型、ID及說(shuō)明如表5-3所示。</p><p><b>  圖5-3登錄界面</b></p><p>  表5-4登陸界面控件表</p><p>  5.4.2

60、倉(cāng)庫(kù)管理模塊設(shè)計(jì)</p><p>  倉(cāng)庫(kù)管理包括新機(jī)入庫(kù)、外借/歸還、樣機(jī)掛失、樣機(jī)信息查詢和外借信息查詢5個(gè)部分,下面分別介紹這5部分的功能以及實(shí)現(xiàn)過(guò)程。</p><p><b>  1新機(jī)登記</b></p><p>  新機(jī)登記管理包括了新機(jī)入庫(kù)、查詢機(jī)型和顯示所有機(jī)型的功能。為了方便添加新機(jī)和查詢所有機(jī)型的基本信息,可以創(chuàng)建一個(gè)對(duì)話框

61、,界面如圖5-4所示。添加的對(duì)話框類(lèi)名稱(chēng)為CNewBooksDlg,資源 ID為 IDD_DALOG_NEW_BOOKS,對(duì)話框名稱(chēng)為“新機(jī)登記入庫(kù)”。</p><p>  圖5-4新機(jī)登記入庫(kù)界面</p><p>  “新機(jī)登記入庫(kù)”對(duì)話框中的控件類(lèi)型、ID及說(shuō)明如表5-5所示。</p><p>  表5-5新機(jī)登記控件列表</p><p>

62、;<b> ?。霂?kù)</b></p><p>  入庫(kù)是倉(cāng)庫(kù)管理系統(tǒng)中最重要的功能之一,是倉(cāng)庫(kù)管理系統(tǒng)不可缺少的。入庫(kù)的實(shí)現(xiàn)過(guò)程是首先要輸入機(jī)器的各種信息,包括機(jī)器的串號(hào)、機(jī)器名稱(chēng)、產(chǎn)地、進(jìn)口商、單價(jià)、總量、現(xiàn)存量等,這里機(jī)器的數(shù)量由兩個(gè)變量來(lái)記錄,總量代表倉(cāng)庫(kù)中這種書(shū)的總量,現(xiàn)存量是目前正在倉(cāng)庫(kù)中的量,兩者之差就是被職員借出去的數(shù)量。其中每個(gè)信息不能有遺漏或者格式不正確,因?yàn)檫@是每一臺(tái)機(jī)器

63、的基本信息,在函數(shù)的實(shí)現(xiàn)過(guò)程中有檢驗(yàn)的功能。然后判斷倉(cāng)庫(kù)中是否存在這種圖書(shū),如果存在,那么只是簡(jiǎn)單地把庫(kù)存的數(shù)量加上新加入的數(shù)量,如果不存在,那么就要新建記錄。函數(shù)為CNewBooksDlg::OnButtonIn(),代碼如下。</p><p>  void CNewBooksDlg::OnButtonIn() </p><p><b>  {</b></p&

64、gt;<p>  // TODO: Add your control notification handler code here</p><p>  UpdateData();</p><p>  if(m_strBookID.Compare("")==0)</p><p><b>  {</b></p

65、><p>  MessageBox("請(qǐng)正確填寫(xiě)要求的數(shù)據(jù)","新機(jī)入庫(kù)登記");</p><p><b>  return;</b></p><p><b>  }</b></p><p>  if(!m_database.IsOpen())</p>

66、<p><b>  {</b></p><p>  if(!m_database.Open(_T("Library")))</p><p><b>  {</b></p><p>  MessageBox("Cannot access database!","

67、新機(jī)登記");</p><p><b>  return;</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  CBookSet *m_pset=new CBookSet(&m_database);<

68、;/p><p>  //判斷倉(cāng)庫(kù)中是否有該機(jī)器,進(jìn)行相應(yīng)操作</p><p>  //有,把數(shù)量加到庫(kù)中</p><p>  CString strSQL;</p><p>  strSQL.Format("select * from Book_Info where Book_ID='%s'",m_strBoo

69、kID);</p><p>  m_pset->Open(AFX_DB_USE_DEFAULT_TYPE,strSQL);</p><p>  if(m_pset->GetRecordCount()!=0)</p><p><b>  {</b></p><p>  m_pset->Edit();<

70、;/p><p>  m_pset->m_Total_Amount=m_pset->m_Total_Amount+m_lTotal;</p><p>  m_pset->m_Now_Amount=m_pset->m_Now_Amount+m_lNow;</p><p>  m_pset->Update();</p><p&

71、gt;  m_pset->Requery();</p><p>  m_pset->Close();</p><p>  m_database.Close();</p><p>  MessageBox("Adding new books successfully!","新機(jī)入庫(kù)登記");</p>&

72、lt;p>  OnButtonCheckBooks();</p><p><b>  return;</b></p><p><b>  }</b></p><p>  m_pset->Close();</p><p>  if(m_strBookID==""||m_

73、strBookName==""||m_strWriter==""</p><p>  ||m_strPress==""||m_dPrice==0||m_lTotal==0</p><p>  ||m_lNow==0)</p><p><b>  {</b></p><

74、;p>  MessageBox("請(qǐng)正確填寫(xiě)要求的數(shù)據(jù)!","新機(jī)登記入庫(kù)");</p><p>  m_database.Close();</p><p><b>  return;</b></p><p><b>  }</b></p><p>  

75、strSQL.Format("select * from Book_Info");</p><p>  m_pset->Open(AFX_DB_USE_DEFAULT_TYPE,strSQL);</p><p>  //if(m_pset->GetRecordCount()==0)</p><p><b>  //{<

76、/b></p><p>  //MessageBox("There are not any book information!","新機(jī)登記");</p><p><b>  //}</b></p><p>  m_pset->AddNew();</p><p>  m

77、_pset->SetFieldNull(&(m_pset->m_Book_ID),FALSE);</p><p>  m_pset->m_Book_ID=m_strBookID;</p><p>  m_pset->SetFieldNull(&(m_pset->m_Book_Name),FALSE);</p><p> 

78、 m_pset->m_Book_Name=m_strBookName;</p><p>  m_pset->SetFieldNull(&(m_pset->m_Writer),FALSE);</p><p>  m_pset->m_Writer=m_strWriter;</p><p>  m_pset->SetFieldNull

79、(&(m_pset->m_Press),FALSE);</p><p>  m_pset->m_Press=m_strPress;</p><p>  m_pset->SetFieldNull(&(m_pset->m_Price),FALSE);</p><p>  m_pset->m_Price=m_dPrice;&l

80、t;/p><p>  m_pset->SetFieldNull(&(m_pset->m_Total_Amount),FALSE);</p><p>  m_pset->m_Total_Amount=m_lTotal;</p><p>  m_pset->SetFieldNull(&(m_pset->m_Now_Amount)

81、,FALSE);</p><p>  m_pset->m_Now_Amount=m_lNow;</p><p>  CTime curTime=CTime::GetCurrentTime();</p><p>  m_pset->SetFieldNull(&(m_pset->m_InLibrary_Date),FALSE);</p&g

82、t;<p>  m_pset->m_InLibrary_Date=curTime;</p><p>  m_pset->Update();</p><p>  m_pset->Requery();</p><p>  m_pset->Close();</p><p>  m_database.Close(

83、);</p><p>  MessageBox("添加成功!","新機(jī)入庫(kù)登記");</p><p>  OnButtonCheckBooks();</p><p>  m_strBookID.Empty();</p><p>  m_strBookName.Empty();</p>&l

84、t;p>  m_strPress.Empty();</p><p>  m_strWriter.Empty();</p><p><b>  m_lNow=0;</b></p><p>  m_lTotal=0;</p><p>  m_dPrice=0.0;</p><p>  Updat

85、eData(FALSE);</p><p><b>  return;</b></p><p><b>  }</b></p><p>  void CNewBooksDlg::OnButtonCheckBooks() </p><p><b>  {</b></p>

86、;<p>  // TODO: Add your control notification handler code here</p><p>  UpdateData();</p><p>  if(m_strBookID=="")</p><p><b>  {</b></p><p&g

87、t;  MessageBox("請(qǐng)正確填寫(xiě)信息,(串號(hào)?)","新機(jī)登記");</p><p><b>  return;</b></p><p><b>  }</b></p><p>  if(!m_database.IsOpen())</p><p>&

88、lt;b>  {</b></p><p>  if(!m_database.Open(_T("Library")))</p><p><b>  {</b></p><p>  MessageBox("不能添加這個(gè)機(jī)型!","新機(jī)登記");</p>&l

89、t;p><b>  return;</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  CBookSet *m_pset=new CBookSet(&m_database);</p><p>  CStrin

90、g strSQL;</p><p>  strSQL.Format("select * from Book_Info where Book_ID='%s'",m_strBookID);</p><p>  m_pset->Open(AFX_DB_USE_DEFAULT_TYPE,strSQL);</p><p>  if(m

91、_pset->GetRecordCount()==0)</p><p><b>  {</b></p><p>  MessageBox("沒(méi)有這個(gè)機(jī)型!","新機(jī)登記");</p><p>  m_database.Close();</p><p><b>  r

92、eturn;</b></p><p><b>  }</b></p><p><b>  //處理表格</b></p><p>  m_ctrList.DeleteAllItems();</p><p>  m_pset->MoveFirst();</p><p

93、>  char buf[50];</p><p>  CDBVariant varValue;</p><p><b>  int i=0;</b></p><p>  CString strBookName;</p><p>  while(!m_pset->IsEOF())</p><

94、p><b>  {</b></p><p>  m_ctrList.InsertItem(i,buf);</p><p>  m_ctrList.SetItemText(i,0,m_strBookID);</p><p>  m_pset->GetFieldValue(1,strBookName);</p><p

95、>  m_ctrList.SetItemText(i,1,strBookName);</p><p>  m_pset->GetFieldValue(2,strBookName);</p><p>  m_ctrList.SetItemText(i,2,strBookName);</p><p>  m_pset->GetFieldValue(3,

96、strBookName);</p><p>  m_ctrList.SetItemText(i,3,strBookName);</p><p>  m_pset->GetFieldValue(4,varValue);</p><p>  sprintf(buf,"%.2f",varValue.m_dblVal);</p>&l

97、t;p>  m_ctrList.SetItemText(i,4,buf);</p><p>  m_pset->GetFieldValue(5,varValue);</p><p>  sprintf(buf,"%d-%d-%d",varValue.m_pdate->year,varValue.m_pdate->month,</p>

98、<p>  varValue.m_pdate->day);</p><p>  m_ctrList.SetItemText(i,5,buf);</p><p>  m_pset->GetFieldValue(6,varValue);</p><p>  sprintf(buf,"%d",varValue.m_lVal);&

99、lt;/p><p>  m_ctrList.SetItemText(i,6,buf);</p><p>  m_pset->GetFieldValue(7,varValue);</p><p>  sprintf(buf,"%d",varValue.m_lVal);</p><p>  m_ctrList.SetItem

100、Text(i,7,buf);</p><p><b>  i++;</b></p><p>  m_pset->MoveNext();</p><p>  UpdateData(FALSE);</p><p><b>  }</b></p><p>  這里需要用到 C

101、BookSet類(lèi),所以要在 NewBooksDlg.cpp文件的開(kāi)始處引入 BookSet.h文件,方法如下。</p><p>  #inclue”BookSet.h”</p><p>  OnButtonlh函數(shù)首先調(diào)用 UPdateData(),完成從控件到對(duì)話框成員變量的數(shù)據(jù)交換,然后判斷是否輸入了機(jī)器ID,如果輸入為空,將不能正確地將新機(jī)入庫(kù),函數(shù)返回錯(cuò)誤。判斷數(shù)據(jù)庫(kù)是否打開(kāi),如果

102、役有打開(kāi),那么重新打開(kāi)數(shù)據(jù)庫(kù)。生成新的CBookSet實(shí)例,與數(shù)據(jù)庫(kù)綁定,輸入SQL語(yǔ)句,查找數(shù)據(jù)庫(kù)倉(cāng)庫(kù)中是否有該機(jī)型,進(jìn)行相應(yīng)操作,如果有,把數(shù)量加到庫(kù)中;如果役有,那么要在數(shù)據(jù)庫(kù)中建立新的機(jī)型記錄。</p><p><b>  .查詢</b></p><p>  查詢也是很重要的一個(gè)功能,在很多地方會(huì)被用到,也是顯示數(shù)據(jù)的一個(gè)功能函數(shù)。實(shí)現(xiàn)的過(guò)程,也是首先檢查數(shù)據(jù)

103、庫(kù)是否打開(kāi),以及要查詢的機(jī)型ID是否為空。函數(shù)為CNewBooksDlg::OnButtouln(),代碼如下。</p><p>  void CNewBooksDlg::OnButtonCheckBooks() </p><p><b>  {</b></p><p>  // TODO: Add your control notificat

104、ion handler code here</p><p>  UpdateData();</p><p>  if(m_strBookID=="")</p><p><b>  {</b></p><p>  MessageBox("請(qǐng)正確填寫(xiě)信息,(串號(hào)?)","新機(jī)

105、登記");</p><p><b>  return;</b></p><p><b>  }</b></p><p>  if(!m_database.IsOpen())</p><p><b>  {</b></p><p>  if(!m

106、_database.Open(_T("Library")))</p><p><b>  {</b></p><p>  MessageBox("不能添加這個(gè)機(jī)型!","新機(jī)登記");</p><p><b>  return;</b></p>&l

107、t;p><b>  }</b></p><p><b>  }</b></p><p>  CBookSet *m_pset=new CBookSet(&m_database);</p><p>  CString strSQL;</p><p>  strSQL.Format(&qu

108、ot;select * from Book_Info where Book_ID='%s'",m_strBookID);</p><p>  m_pset->Open(AFX_DB_USE_DEFAULT_TYPE,strSQL);</p><p>  if(m_pset->GetRecordCount()==0)</p><p&g

109、t;<b>  {</b></p><p>  MessageBox("沒(méi)有這個(gè)機(jī)型!","新機(jī)登記");</p><p>  m_database.Close();</p><p><b>  return;</b></p><p><b>  }

110、</b></p><p><b>  //處理表格</b></p><p>  m_ctrList.DeleteAllItems();</p><p>  m_pset->MoveFirst();</p><p>  char buf[50];</p><p>  CDBVari

111、ant varValue;</p><p><b>  int i=0;</b></p><p>  CString strBookName;</p><p>  while(!m_pset->IsEOF())</p><p><b>  {</b></p><p> 

112、 m_ctrList.InsertItem(i,buf);</p><p>  m_ctrList.SetItemText(i,0,m_strBookID);</p><p>  m_pset->GetFieldValue(1,strBookName);</p><p>  m_ctrList.SetItemText(i,1,strBookName);<

113、/p><p>  m_pset->GetFieldValue(2,strBookName);</p><p>  m_ctrList.SetItemText(i,2,strBookName);</p><p>  m_pset->GetFieldValue(3,strBookName);</p><p>  m_ctrList.Set

114、ItemText(i,3,strBookName);</p><p>  m_pset->GetFieldValue(4,varValue);</p><p>  sprintf(buf,"%.2f",varValue.m_dblVal);</p><p>  m_ctrList.SetItemText(i,4,buf);</p>

115、;<p>  m_pset->GetFieldValue(5,varValue);</p><p>  sprintf(buf,"%d-%d-%d",varValue.m_pdate->year,varValue.m_pdate->month,</p><p>  varValue.m_pdate->day);</p>

116、<p>  m_ctrList.SetItemText(i,5,buf);</p><p>  m_pset->GetFieldValue(6,varValue);</p><p>  sprintf(buf,"%d",varValue.m_lVal);</p><p>  m_ctrList.SetItemText(i,6,b

117、uf);</p><p>  m_pset->GetFieldValue(7,varValue);</p><p>  sprintf(buf,"%d",varValue.m_lVal);</p><p>  m_ctrList.SetItemText(i,7,buf);</p><p><b>  i++

118、;</b></p><p>  m_pset->MoveNext();</p><p>  UpdateData(FALSE);</p><p><b>  }</b></p><p>  m_pset->Close();</p><p>  m_database.Clos

119、e();</p><p><b>  }</b></p><p>  OnButtonCheckBooks函數(shù)開(kāi)始部分與新機(jī)入庫(kù)函數(shù)類(lèi)似,都是首先進(jìn)行數(shù)據(jù)交換,然后判斷輸入機(jī)型ID是否為空,判斷數(shù)據(jù)庫(kù)是否正常打開(kāi),生成新的BookSet實(shí)例。以上函數(shù)處理時(shí),注意在數(shù)據(jù)庫(kù)的數(shù)據(jù)取出來(lái)之后,CBookSet類(lèi)的實(shí)例m_pset通過(guò)GetFieldValue函數(shù)來(lái)取得每個(gè)字

120、段的值。在這里需要的值都是CString類(lèi)型,故而直接使用GetFieldValue就可以了。如果有別的類(lèi)型,比如整型,實(shí)型等,就需要將得到的結(jié)果進(jìn)行類(lèi)型轉(zhuǎn)換。</p><p><b>  .顯示全部機(jī)型</b></p><p>  顯示全部機(jī)型部分的處理函數(shù)跟查詢的基本類(lèi)似,相應(yīng)的 SQL語(yǔ)句為“select*form BOOk_Info”,然后依次插入列表控件中,

121、這部分代碼省略。</p><p><b>  2外借/歸還</b></p><p>  外借/歸還管理是庫(kù)存管理系統(tǒng)中最重要的模塊,包括了查詢機(jī)型、查詢外借人信息和外借、歸還等功能。為了方便管理,可以創(chuàng)建一個(gè)對(duì)話框。添加的對(duì)話框類(lèi)名稱(chēng)為 CBorrowDlg,</p><p>  資源ID為IDD_DIALOG BORROW,對(duì)話框名稱(chēng)為“外借

122、/歸還管理”,界面如圖5-6所示。</p><p>  圖5-6樣機(jī)管理界面</p><p>  “外借/歸還管理”對(duì)話框中的控件類(lèi)型、ID及說(shuō)明如表5-6所示。</p><p>  表5-6樣機(jī)管理控件表</p><p><b> ?。樵儥C(jī)型</b></p><p>  查詢機(jī)型的處理函數(shù)為

123、CBorrowDlg::OnButtonCheckBooks()代碼如下。</p><p>  void CBorrowDlg::OnButtonCheckBooks() </p><p><b>  {</b></p><p>  // TODO: Add your control notification handler code here

124、</p><p>  CCheckBooksDlg m_dlg;</p><p>  m_dlg.DoModal();</p><p><b>  }</b></p><p>  為了方便處理,新建一個(gè)對(duì)話框,添加的對(duì)話框類(lèi)名稱(chēng)為 CCheckBooksDlg,資源 ID為</p><p>  I

溫馨提示

  • 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)論