倉(cāng)庫(kù)管理系統(tǒng)畢業(yè)設(shè)計(jì)
專業(yè)綜合設(shè)計(jì)
系統(tǒng)名稱: 倉(cāng)庫(kù)管理系統(tǒng)
學(xué) 校: XXXXXXXXXXXXXXXX學(xué)院
系 別: 計(jì)算機(jī)科學(xué)與應(yīng)用系s
專 業(yè): 計(jì)算機(jī)科學(xué)與技術(shù)
姓 名: XXX
學(xué) 號(hào): XXXXXXXXX
指導(dǎo)教師: XX
日 期: 201X年X年X日
摘 要
隨著現(xiàn)代工業(yè)的發(fā)展,計(jì)算機(jī)信息管理系統(tǒng)越來(lái)越受到企業(yè)重視,庫(kù)存管理系統(tǒng)是典型的信息管理系統(tǒng)(MIS),其開發(fā)主要包括后臺(tái)數(shù)據(jù)庫(kù)的建立和維護(hù)以及前端應(yīng)用程序的開發(fā)兩個(gè)方面。對(duì)于前者要求建立一個(gè)數(shù)據(jù)一致性、完整性以及安全性好的庫(kù)。而對(duì)于后者則要求應(yīng)用程序功能完備,易使用等特點(diǎn)。
本設(shè)計(jì)采用Visual Studio 2005的開發(fā)環(huán)境,而后臺(tái)數(shù)據(jù)庫(kù)選用數(shù)據(jù)庫(kù)軟件SQL Server 2005,主要完成了庫(kù)存管理系統(tǒng)的需求分析、功能模塊的劃分、數(shù)據(jù)庫(kù)模式分析,并由此完成了數(shù)據(jù)庫(kù)結(jié)構(gòu)和應(yīng)用程序的實(shí)現(xiàn),系統(tǒng)基本實(shí)現(xiàn)了所需功能,界面友好,操作方便。
本系統(tǒng)主要是讓倉(cāng)庫(kù)的管理實(shí)現(xiàn)信息化、系統(tǒng)化,方便化,把計(jì)算機(jī)用于倉(cāng)庫(kù)管理中,這樣可以很大程度上提高管理者分析和決策的科學(xué)性,提高經(jīng)營(yíng)管理水平。
關(guān)鍵詞:倉(cāng)庫(kù)管理 Visual Studio 2005 SQL Server 2005
ABSTRACT
With the development of modern industry, the information management system of the computer is being paid attention to by enterprises. The stock management system is a typical MIS.It’s development mostly include the foundation and maintenance of the Database and the development of the client application programme.For the former we must eatablish a better database,which has well data consistency and data security.For the latter we must make the programme has self-contained function and easy to be use.
The design of the development environment using Visual studio 2005 , the database software is SQL Server 2005,mainly completed inventory management system needs analysis, the division of functional modules, the database model analysis, and thus completed the database structure and application implementation, The system basically achieves the required function, its interface is good, and is used well.
The system is designed to allow the management informationized and systematic, used computer in the catering management of supermarket, so it can improve the scientific of ana- lysis and decision-making,and enhance the management level.
Keywords: stock management Visual Studio 2005 SQL Server 2005
目 錄
第一章 緒論 1
1.1 倉(cāng)庫(kù)管理系統(tǒng) 1
1.2 倉(cāng)庫(kù)管理系統(tǒng)的研究背景與意義 1
第二章 開發(fā)工具簡(jiǎn)介 3
2.1 Visual Stdio 2005簡(jiǎn)介 3
2.2 SQL Server 2005簡(jiǎn)介 3
第三章 倉(cāng)庫(kù)管理系統(tǒng)分析 4
3.1 開發(fā)系統(tǒng)的目的 4
3.2 需求分析 4
3.3 可行性分析 5
3.3.1 技術(shù)可行性 5
3.3.2 經(jīng)濟(jì)可行性 5
3.3.3 管理可行性 5
3.3.4 社會(huì)可行性 6
3.5 系統(tǒng)流程圖 7
第四章 倉(cāng)庫(kù)管理系統(tǒng)數(shù)據(jù)庫(kù)分析 8
4.1 數(shù)據(jù)庫(kù)介紹 8
4.1.1 用戶數(shù)據(jù) 8
4.2 創(chuàng)建數(shù)據(jù)庫(kù) 9
第五章 倉(cāng)庫(kù)管理系統(tǒng)數(shù)據(jù)庫(kù)設(shè)計(jì) 10
5.1 數(shù)據(jù)庫(kù)概念設(shè)計(jì) 10
5.2 倉(cāng)庫(kù)管理系統(tǒng)E-R圖 11
5.3 倉(cāng)庫(kù)管理系統(tǒng)數(shù)據(jù)表清單 12
5.4 數(shù)據(jù)庫(kù)邏輯結(jié)構(gòu)設(shè)計(jì) 12
第六章 界面展示及部分功能模塊主要代碼 17
6.1 模塊劃分 17
6.2 本程序登錄界面 17
6.3 本程序運(yùn)行后的效果 18
6.4 選擇主窗體 19
6.4.1 入庫(kù)管理窗體 20
6.4.2 出庫(kù)管理窗體 21
6.4.3 借貨管理窗體 23
6.4.4 還貨管理窗體 24
6.4.5 盤點(diǎn)管理窗體 26
6.5 選擇主窗體 27
6.5.1 供應(yīng)商信息窗體 28
6.5.2 倉(cāng)庫(kù)管理窗體 29
6.5.3 貨物管理窗體 30
6.6 選擇主窗體 31
6.6.1 數(shù)據(jù)備份窗體 32
6.6.2 數(shù)據(jù)還原窗體 33
6.6.3 數(shù)據(jù)壓縮窗體 34
6.7 選擇主窗體 36
6.7.1 更改密碼窗體 36
6.7.2 用戶管理窗體 37
6.8 選擇主窗體 39
6.8.1 庫(kù)存查詢界面 40
第七章 軟件測(cè)試及維護(hù) 43
第八章 致謝 45
第九章 結(jié)論 46
參考文獻(xiàn) 47
IV
第一章 緒論
1.1 倉(cāng)庫(kù)管理系統(tǒng)
當(dāng)今時(shí)代是飛速發(fā)展的信息時(shí)代,在各行各業(yè)中離不開信息處理,計(jì)算機(jī)最大的好處在于利用它能夠進(jìn)行信息管理,使用計(jì)算機(jī)進(jìn)行信息控制,不僅提高了工作效率,而且大大的提高了其安全性,尤其針對(duì)復(fù)雜的信息管理,計(jì)算機(jī)能夠充分發(fā)揮它的優(yōu)越性。計(jì)算機(jī)進(jìn)行信息管理與信息管理系統(tǒng)的開發(fā)密切相關(guān),系統(tǒng)的開發(fā)是系統(tǒng)管理的前提。
倉(cāng)庫(kù)作為一種貨品資源的集散地,貨品的種類繁多,包含很多的信息數(shù)據(jù)的管理。據(jù)調(diào)查得知,以前倉(cāng)庫(kù)進(jìn)行信息管理的方式主要是基于文本、表格等介質(zhì)的手工處理,對(duì)于貨品的出入庫(kù)情況的統(tǒng)計(jì)和核實(shí)等往往采用對(duì)賬本的人工檢查,對(duì)管理者的管理權(quán)限等不受約束,任何人都可查看,這樣容易引起資料外泄。另外,數(shù)據(jù)信息處理工作量大,容易出錯(cuò),數(shù)據(jù)繁多,容易丟失,且不易查找??偟膩?lái)說,缺乏系統(tǒng)、規(guī)范的信息管理手段。而且,一般的存儲(chǔ)情況是記錄在賬本上的,倉(cāng)庫(kù)的工作人員和管理員也只是當(dāng)時(shí)記得比較清楚,時(shí)間一長(zhǎng),如果再要進(jìn)行查詢,就得在眾多的資料中翻閱查找了,這樣造成費(fèi)時(shí)、費(fèi)力,如要對(duì)很長(zhǎng)時(shí)間以前的貨品進(jìn)行更改就更加困難了。因此,很有必要建立一個(gè)庫(kù)存管理系統(tǒng),使貨品管理工作規(guī)范化、系統(tǒng)化、程序化。提高信息處理的速度和準(zhǔn)確性。
1.2 倉(cāng)庫(kù)管理系統(tǒng)的研究背景與意義
眾所周知,倉(cāng)庫(kù)管理是一種既麻煩又單調(diào)的工作,每天都是重復(fù)記錄一些貨物的存入與取出,而且貨物的種類繁多,存取有很大的隨機(jī)性,這樣為工作人員帶來(lái)了很大的不便,在操作過程中,由于人為的計(jì)算出錯(cuò)率很高,一旦出錯(cuò)改正也很困難,這樣簡(jiǎn)單繁重的工作要很多人來(lái)做,為經(jīng)營(yíng)者增加了很多成本,所以開發(fā)一個(gè)可行的倉(cāng)庫(kù)管理系統(tǒng)是十分必要的。
隨著我國(guó)經(jīng)濟(jì)的飛速發(fā)展,各種類型規(guī)模的公司企業(yè)迅速崛起,許多從事生產(chǎn)和經(jīng)營(yíng)管理的企業(yè)都有自己生產(chǎn)和銷售的產(chǎn)品,而這些產(chǎn)品都需要儲(chǔ)存在倉(cāng)庫(kù)中,對(duì)于每個(gè)企業(yè)來(lái)說,隨著企業(yè)規(guī)模的不斷擴(kuò)大,產(chǎn)品數(shù)量的急劇增加,所生產(chǎn)產(chǎn)品的種類也會(huì)不斷地更新與發(fā)展,有關(guān)產(chǎn)品的各種信息量也會(huì)成倍增長(zhǎng)。面對(duì)龐大的產(chǎn)品信息量,如何有效地管理庫(kù)存產(chǎn)品,對(duì)這些企業(yè)來(lái)說是非常重要的,庫(kù)存管理的重點(diǎn)是銷售信息能否及時(shí)反饋,從而確保企業(yè)運(yùn)行效益。而庫(kù)存管理又涉及入庫(kù)、出庫(kù)的產(chǎn)品、經(jīng)辦人員及客戶等方方面面的因素,如何管理這些信息數(shù)據(jù),是一項(xiàng)復(fù)雜的系統(tǒng)工程,充分考驗(yàn)著倉(cāng)庫(kù)管理員的工作能力,工作量的繁重是可想而知的,所以這就需要由倉(cāng)庫(kù)管理系統(tǒng)來(lái)提高庫(kù)存管理工作的效率,這對(duì)信息的規(guī)范管理、科學(xué)統(tǒng)計(jì)和快速查詢,減少管理方面的工作量,同時(shí)對(duì)于調(diào)動(dòng)廣大員工的工作積極性,提高企業(yè)的生產(chǎn)效率,都具有十分重要的現(xiàn)實(shí)意義。
第二章 開發(fā)工具簡(jiǎn)介
2.1 Visual Stdio 2005簡(jiǎn)介
開發(fā)這個(gè)系統(tǒng)使用Visual Stdio 2005工具來(lái)開發(fā), Visual Stdio 2005是當(dāng)前最流行的一款程序開發(fā)工具,利用它可以開發(fā)功能強(qiáng)大的、運(yùn)行在Windows平臺(tái)上的、能夠操作數(shù)據(jù)庫(kù)的應(yīng)用系統(tǒng),因此能夠適應(yīng)我們開發(fā)本系統(tǒng)的要求,并且簡(jiǎn)單易用,實(shí)現(xiàn)功能的代碼量比其他語(yǔ)言減少許多,這樣就縮短了軟件開發(fā)周期,大大節(jié)約了軟件開發(fā)成本。
2.2 SQL Server 2005簡(jiǎn)介
SQL Server 2005 是一個(gè)全面的數(shù)據(jù)庫(kù)平臺(tái),使用集成的商業(yè)智能 (BI) 工具提供了企業(yè)級(jí)的數(shù)據(jù)管理,SQL Server 2005 數(shù)據(jù)庫(kù)引擎為關(guān)系型數(shù)據(jù)和結(jié)構(gòu)化數(shù)據(jù)提供了更安全可靠的存儲(chǔ)功能。SQL Server 2005 中包含了非常豐富的新特性:通過提供一個(gè)更安全、可靠和高效的數(shù)據(jù)管理平臺(tái),增強(qiáng)企業(yè)組織中用戶的管理能力,大幅提升IT管理效率并降低運(yùn)維風(fēng)險(xiǎn)和成本;通過提供先進(jìn)的商業(yè)智能平臺(tái)滿足眾多客戶對(duì)業(yè)務(wù)的實(shí)時(shí)統(tǒng)計(jì)分析、監(jiān)控預(yù)測(cè)等多種復(fù)雜管理需求,推動(dòng)企業(yè)管理信息化建設(shè)和業(yè)務(wù)發(fā)展;同時(shí),SQL Server 2005將提供一個(gè)極具擴(kuò)展性和靈活性的開發(fā)平臺(tái),實(shí)現(xiàn)Internet數(shù)據(jù)業(yè)務(wù)互聯(lián)。
第三章 倉(cāng)庫(kù)管理系統(tǒng)分析
3.1 開發(fā)系統(tǒng)的目的
開發(fā)倉(cāng)庫(kù)管理系統(tǒng),主要為減輕倉(cāng)庫(kù)管理人員的負(fù)擔(dān),使貨物的存入記錄與取出記錄相對(duì)完善,便于貨物的增加與減少,降低出錯(cuò)率,使管理更加合理、科學(xué),也為經(jīng)營(yíng)者節(jié)省開支。本系統(tǒng)完面考慮了倉(cāng)庫(kù)在管理中要解決的所有需求,最終向用戶提供一套方便可行的系統(tǒng),該系統(tǒng)具備以下特征:配置必要的數(shù)據(jù)庫(kù)和應(yīng)用服務(wù)程序,提供查詢、統(tǒng)計(jì)貨物的種類、數(shù)量及所屬公司等所有信息的功能,操作人員使用的界面要清晰、美觀,布局合理,內(nèi)容盡量簡(jiǎn)單明了,提供的信息詳細(xì)全面??蛻舳顺绦蛞蟀踩愿撸煽啃愿?。
3.2 需求分析
市場(chǎng)經(jīng)濟(jì)的一個(gè)重要特征,就是生產(chǎn)的相對(duì)過剩和產(chǎn)品的相對(duì)過剩。它決定了這是一個(gè)買方市場(chǎng)。對(duì)企業(yè)來(lái)說,庫(kù)存的增加或積壓,無(wú)論是原材料、半成品或制成品,都意味著企業(yè)運(yùn)作處于一種不良的狀態(tài),都是一種直接的或潛在的損失。大量的庫(kù)存擠占了企業(yè)的有限資金,使得資金流速減緩,現(xiàn)金流發(fā)生困難,甚至導(dǎo)致資金緊張,影響企業(yè)的正常運(yùn)作。此外,大量的庫(kù)存增加了保管與倉(cāng)儲(chǔ)的壓力,占用了相當(dāng)?shù)娜肆臀锪?,使得企業(yè)負(fù)擔(dān)加重。凡此種種,一直困擾著企業(yè)的生產(chǎn)經(jīng)營(yíng)管理活動(dòng),影響企業(yè)經(jīng)濟(jì)效益的實(shí)現(xiàn)。顯而易見,切實(shí)而有效地控制庫(kù)存,是擺在眾多企業(yè)面前的當(dāng)務(wù)之急,也是緩解企業(yè)經(jīng)濟(jì)壓力、減負(fù)增效的重要途徑。
需求分析是軟件定義時(shí)期的最后一個(gè)階段,它的基本任務(wù)是準(zhǔn)確地回答“系統(tǒng)必須做什么”這個(gè)問題,是對(duì)目標(biāo)系統(tǒng)提出完整、準(zhǔn)確、清晰、具體的要求。需求分析的結(jié)果是系統(tǒng)開發(fā)的基礎(chǔ),關(guān)系到工程的成敗和軟件產(chǎn)品的質(zhì)量。因此,必須用行之有效的方法對(duì)軟件需求進(jìn)行嚴(yán)格的審查驗(yàn)證。
軟件需求分析過程是整個(gè)系統(tǒng)開發(fā)的重要階段,分析的成功與否,決定著整個(gè)系統(tǒng)功能的完善性以及穩(wěn)定性。在該階段分析人員需要確定整個(gè)產(chǎn)品的功能要求,并將提供一種可轉(zhuǎn)化為數(shù)據(jù)設(shè)計(jì)、結(jié)構(gòu)設(shè)計(jì)和過程設(shè)計(jì)的數(shù)據(jù)與功能表示。在軟件完成后,需求分析階段研究的對(duì)象是軟件項(xiàng)目的用戶要求。
3.3 可行性分析
可行性研究的目的就是用最小的代價(jià)在盡可能短的時(shí)間內(nèi)確定問題是否能夠解決。要達(dá)到這個(gè)目的,必須分析幾種主要的可能解法的利弊,從而判斷原定的系統(tǒng)規(guī)模和目標(biāo)是 的效益是否達(dá)到值得投資開發(fā)這個(gè)系統(tǒng)的程度。一般來(lái)說,可行性分析應(yīng)從經(jīng)濟(jì)可行性、技術(shù)可行性、經(jīng)濟(jì)可行性、操作可行性、社會(huì)可行性等方面進(jìn)行研究。本系統(tǒng)的可行性分析如下:
3.3.1 技術(shù)可行性
隨著國(guó)內(nèi)軟件開發(fā)的日益發(fā)展壯大,各種中小企事業(yè)單位已具備獨(dú)立開發(fā)各種類型的軟件的能力,能夠滿足不同行業(yè)的特別的需求,現(xiàn)在,市場(chǎng)上可以選購(gòu)的應(yīng)用開發(fā)產(chǎn)品很多,流行的也有數(shù)十種。此外,從開發(fā)人員的水平考慮,作為計(jì)算機(jī)科學(xué)與技術(shù)專業(yè)畢業(yè)的學(xué)生,大學(xué)四年所積累的專業(yè)知識(shí)使我們從一定程度上具備了開發(fā)一個(gè)小型系統(tǒng)的能力,而且學(xué)?,F(xiàn)有的計(jì)算機(jī)設(shè)備也完全能夠滿足開發(fā)的需要。本系統(tǒng)主要管理的是貨物的入庫(kù),出庫(kù),查詢相關(guān)的一些信息等,采用C#和Microsoft Visual Studio作為前臺(tái)用戶界面的開發(fā)語(yǔ)言和工具,而后臺(tái)的數(shù)據(jù)庫(kù)采用微軟的SQL Server 2005。由于主要采用數(shù)據(jù)庫(kù)來(lái)進(jìn)行管理,實(shí)現(xiàn)起來(lái)比較簡(jiǎn)單,從技術(shù)上來(lái)說是完全可行的。
3.3.2 經(jīng)濟(jì)可行性
對(duì)于整個(gè)系統(tǒng)而言,在系統(tǒng)未運(yùn)行之前,初期投資比較大,花費(fèi)相當(dāng)而言比較多。各部門必須配置電腦、服務(wù)器、打印機(jī)、傳真機(jī)及相關(guān)的網(wǎng)絡(luò)設(shè)備,但是在整個(gè)系統(tǒng)投入運(yùn)行之后,將會(huì)給該企業(yè)帶來(lái)前所未有的方便和快捷,減少不必要的中間環(huán)節(jié)以及不必要的開支,而且可以給其帶來(lái)更大的利潤(rùn)。總之,這個(gè)系統(tǒng)的經(jīng)濟(jì)效益遠(yuǎn)遠(yuǎn)大于開發(fā)成本,而同時(shí)又減少了數(shù)據(jù)的流通環(huán)節(jié),不必要花費(fèi)那么多的時(shí)間,也就是說最重要的就是提高了效率,而又保證了各項(xiàng)數(shù)據(jù)的準(zhǔn)確性,也避免了工作人員的流動(dòng)造成的收據(jù)丟失等問題,適應(yīng)了當(dāng)前的發(fā)展形勢(shì)。
3.3.3 管理可行性
傳統(tǒng)的庫(kù)存管理系統(tǒng),一般有兩種方式:一是手工管理,這種方式應(yīng)用最傳統(tǒng)的“筆紙操作系統(tǒng)”,將庫(kù)存的貨物信息、銷售信息、廠商信息管理及單據(jù)管理等均以純手工的形式進(jìn)行,將信息以表格文件的表現(xiàn)形式記錄在紙上,再進(jìn)行統(tǒng)一保存。這種方式雖然在簡(jiǎn)單信息查詢時(shí)會(huì)有一定的方便,但是存在著更多的不便:信息保存時(shí)間和條件很受限制、容易被損壞、信息查詢不便、信息傳達(dá)容易造成失誤等。另一種常見的信息管理方法是應(yīng)用管理系統(tǒng),本系統(tǒng)就是一款做的相對(duì)到位的庫(kù)存管理系統(tǒng),隨著時(shí)代的發(fā)展,人員素質(zhì)已逐步提高,庫(kù)存管理人員已經(jīng)有豐富的信息管理經(jīng)驗(yàn),不論是對(duì)于電腦系統(tǒng)的基本操作還是對(duì)于系統(tǒng)的維護(hù)都有了一定的基礎(chǔ),同時(shí)還可以配置專業(yè)的電腦維護(hù)人員來(lái)維護(hù)電腦不必?fù)?dān)心電腦故障問題。
3.3.4 社會(huì)可行性
該系統(tǒng)是作為畢業(yè)設(shè)計(jì),不會(huì)對(duì)社會(huì)造成嚴(yán)重影響,也不用考慮到版權(quán)、法律等社會(huì)因素,所以在社會(huì)方面也是可行的。
3.4系統(tǒng)功能描述及系統(tǒng)安全性
一、庫(kù)存管理系統(tǒng)是一套對(duì)貨品入庫(kù)、出庫(kù)、庫(kù)存進(jìn)行全面管理的系統(tǒng),在設(shè)計(jì)該系統(tǒng)時(shí),應(yīng)盡可能便于用戶管理和操作。系統(tǒng)在實(shí)現(xiàn)上應(yīng)該具有如下功能:
(1)系統(tǒng)要求用戶必須輸入正確的用戶名和密碼才能進(jìn)入系統(tǒng)。
(2)系統(tǒng)能實(shí)現(xiàn)貨物的入,出庫(kù)功能。
(3)系統(tǒng)提供查詢現(xiàn)在庫(kù)存的情況,及入庫(kù)、出庫(kù)和貨物年統(tǒng)計(jì)等的記錄。
(4)系統(tǒng)提供管理員設(shè)置倉(cāng)庫(kù)信息和修改貨物信息等。
(5)系統(tǒng)提供管理員增加、刪除、修改用戶賬戶的功能。
二、由于庫(kù)存管理系統(tǒng)包含比較重要的信息,因此,在系統(tǒng)設(shè)計(jì)時(shí)除了注重用戶的需求,還要保證系統(tǒng)的安全性和一致性,該系統(tǒng)中管理權(quán)限上應(yīng)當(dāng)進(jìn)行嚴(yán)格控制,體現(xiàn)如下:
(1)安全性:本系統(tǒng)中共分為三類不同的用戶,分別具有不同的權(quán)限。要想對(duì)該庫(kù)存管理系統(tǒng)進(jìn)行操作就應(yīng)當(dāng)具有某些操作權(quán)限,沒有權(quán)限的用戶將不能通過任何渠道來(lái)登錄該系統(tǒng),查看該系統(tǒng)的任何信息和數(shù)據(jù),以確保系統(tǒng)的嚴(yán)密性和安全性,系統(tǒng)用戶分為管理員用戶和普通用戶,管理員用戶可對(duì)普通用戶信息進(jìn)行增、刪、改,普通用戶則只能查詢。在具體實(shí)現(xiàn)時(shí)還應(yīng)為系統(tǒng)管理員和普通用戶設(shè)定不同的操作權(quán)限,系統(tǒng)管理員應(yīng)當(dāng)可以操作系統(tǒng)的所有模塊,普通用戶對(duì)于貨物管理和基本檔案管理模塊是無(wú)權(quán)使用的。
(2)一致性:系統(tǒng)的數(shù)據(jù)要保證一致性、準(zhǔn)確性,當(dāng)某一數(shù)據(jù)庫(kù)中記錄發(fā)生改變時(shí),與之相關(guān)聯(lián)的數(shù)據(jù)庫(kù)也隨之變化。
3.5 系統(tǒng)流程圖
本系統(tǒng)流程圖如圖3-1所示。
圖3-1 系統(tǒng)流程圖
第四章 倉(cāng)庫(kù)管理系統(tǒng)數(shù)據(jù)庫(kù)分析
4.1 數(shù)據(jù)庫(kù)介紹
數(shù)據(jù)庫(kù)在一個(gè)信息管理系統(tǒng)中占有非常重要的地位,數(shù)據(jù)庫(kù)結(jié)構(gòu)設(shè)計(jì)的好壞將直接對(duì)應(yīng)用系統(tǒng)的效率以及實(shí)現(xiàn)的效果產(chǎn)生影響。合理的數(shù)據(jù)庫(kù)結(jié)構(gòu)設(shè)計(jì)可以提高數(shù)據(jù)存儲(chǔ)的效率,保證數(shù)據(jù)的完整和一致。同時(shí),合理的數(shù)據(jù)庫(kù)結(jié)構(gòu)也將有利于程序的實(shí)現(xiàn)。設(shè)計(jì)數(shù)據(jù)庫(kù)時(shí)應(yīng)該首先充分了解用戶各個(gè)方面的需求,包括現(xiàn)有的以及將來(lái)可能增加的需求。
數(shù)據(jù)庫(kù)設(shè)計(jì)是在既定(本系統(tǒng)使用SQL Server)的數(shù)據(jù)庫(kù)管理系統(tǒng)基礎(chǔ)之上建立數(shù)據(jù)庫(kù)的過程。其過程是將現(xiàn)實(shí)存在的數(shù)據(jù)及其應(yīng)用處理關(guān)系進(jìn)行抽象,從而形成數(shù)據(jù)庫(kù)結(jié)構(gòu)。數(shù)據(jù)庫(kù)是數(shù)據(jù)庫(kù)應(yīng)用程序的核心,數(shù)據(jù)庫(kù)設(shè)計(jì)是建立一個(gè)應(yīng)用程序最重要的一步。一個(gè)好的數(shù)據(jù)庫(kù)結(jié)構(gòu)和文件設(shè)計(jì)可以使系統(tǒng)在已有的條件下具有處理速度快,占用存儲(chǔ)空間少,操作處理過程簡(jiǎn)單,查找容易,系統(tǒng)開銷和費(fèi)用低等特點(diǎn)。具體實(shí)現(xiàn)時(shí),應(yīng)首先明確用戶對(duì)數(shù)據(jù)的需求,在此基礎(chǔ)上,建立數(shù)據(jù)庫(kù)的概念模型,概念模型主要是用來(lái)反映用戶的現(xiàn)實(shí)環(huán)境和需求,它獨(dú)立于具體的數(shù)據(jù)庫(kù)管理系統(tǒng),并且與數(shù)據(jù)庫(kù)怎樣實(shí)現(xiàn)無(wú)關(guān),建立概念模型的主要工具為實(shí)體關(guān)系(E-R)圖,在建立數(shù)據(jù)庫(kù)概念模型之后,要真正實(shí)現(xiàn)與數(shù)據(jù)庫(kù)管理系統(tǒng)的結(jié)合,即能夠由既定的數(shù)據(jù)庫(kù)管理系統(tǒng)所支持,還必須進(jìn)行邏輯結(jié)構(gòu)的設(shè)計(jì),在邏輯設(shè)計(jì)階段,主要完成建立數(shù)據(jù)庫(kù)的邏輯模型,并解決數(shù)據(jù)的完整性、一致性、安全性和有效性等問題;最后一個(gè)階段是數(shù)據(jù)庫(kù)的物理結(jié)構(gòu)設(shè)計(jì),其任務(wù)是為系統(tǒng)邏輯結(jié)構(gòu)模型確定合理的存儲(chǔ)結(jié)構(gòu)、存取方法、以及數(shù)據(jù)表示和數(shù)據(jù)存儲(chǔ)空間分配等內(nèi)容,從而得到具體的數(shù)據(jù)庫(kù)物理結(jié)構(gòu)。
數(shù)據(jù)庫(kù)由DBMS(數(shù)據(jù)庫(kù)管理系統(tǒng))處理,DBMS則由開發(fā)人員和用戶通過應(yīng)用程序直接或間接地使用。它主要包括四個(gè)要素:用戶數(shù)據(jù)、元數(shù)據(jù)、索引和應(yīng)用元數(shù)據(jù)。
4.1.1 用戶數(shù)據(jù)
目前,大多數(shù)主流數(shù)據(jù)庫(kù)管理系統(tǒng)把用戶數(shù)據(jù)表示為關(guān)系?,F(xiàn)在把關(guān)系看作數(shù)據(jù)表,表的列包含域或?qū)傩?,表的行包含?duì)應(yīng)業(yè)務(wù)環(huán)境中的實(shí)體的記錄。并非所有的關(guān)系都同樣符合要求,有些關(guān)系比其它關(guān)系更結(jié)構(gòu)化一些。
(1)元數(shù)據(jù)
數(shù)據(jù)庫(kù)是自描述的,這就意味著它自身包含了它的結(jié)構(gòu)的描述,這種結(jié)構(gòu)的描述稱作元數(shù)據(jù)。因?yàn)镈BMS產(chǎn)品是用來(lái)存儲(chǔ)和操縱表的,所以大多數(shù)產(chǎn)品把元數(shù)據(jù)以表的形式存儲(chǔ),有時(shí)稱作系統(tǒng)表。這些系統(tǒng)表存儲(chǔ)了數(shù)據(jù)庫(kù)中表的情況,指出每一個(gè)表中有多少列,那一列是主關(guān)鍵字,每一列的數(shù)據(jù)類型的描述,它也存儲(chǔ)索引、關(guān)鍵字、規(guī)則和數(shù)據(jù)庫(kù)結(jié)構(gòu)的其他部分。
在表中存儲(chǔ)元數(shù)據(jù)不僅對(duì)DBMS是有效的,對(duì)用戶也是方便的,因?yàn)樗麄兛梢允褂门c查詢用戶數(shù)據(jù)同樣的查詢工具來(lái)查詢?cè)獢?shù)據(jù)。
(2)索引
第三種類型的數(shù)據(jù)改進(jìn)了數(shù)據(jù)庫(kù)的性能和可訪問性,這種數(shù)據(jù)經(jīng)常稱作開銷數(shù)據(jù),盡管有時(shí)也采用其他類型的數(shù)據(jù)結(jié)構(gòu),如鏈表,但它主要還是索引。索引可以用來(lái)排序和快速訪問數(shù)據(jù)。
(3)應(yīng)用元數(shù)據(jù)
存儲(chǔ)在數(shù)據(jù)庫(kù)中的第四種數(shù)據(jù)是應(yīng)用元數(shù)據(jù),它用來(lái)存儲(chǔ)用戶窗體、報(bào)表、查詢和其他形式的查詢組件。并非所有的DBMS都支持應(yīng)用組件,支持組件的DBMS也不一定把全部組件的結(jié)構(gòu)作為應(yīng)用元數(shù)據(jù)存儲(chǔ)在數(shù)據(jù)庫(kù)中。然而,大多數(shù)現(xiàn)代的DBMS產(chǎn)品存儲(chǔ)這種數(shù)據(jù)作為數(shù)據(jù)庫(kù)的一部分。一般來(lái)說,數(shù)據(jù)庫(kù)開發(fā)人員和用戶都不直接訪問應(yīng)用元數(shù)據(jù),相反,他們通過DBMS中的工具來(lái)處理這些數(shù)據(jù)。
4.2 創(chuàng)建數(shù)據(jù)庫(kù)
數(shù)據(jù)庫(kù)模式定義了數(shù)據(jù)庫(kù)的結(jié)構(gòu)、表、關(guān)系、域和業(yè)務(wù)規(guī)則。數(shù)據(jù)庫(kù)模式是一種設(shè)計(jì),數(shù)據(jù)庫(kù)的應(yīng)用正是建立在此基礎(chǔ)上的。
域是一列可能擁有的值的集合。必須為每一個(gè)表的每一列確定域。除了數(shù)據(jù)的物理格式外,還需要確定是否有些域?qū)Ρ韥?lái)說是唯一的。
數(shù)據(jù)庫(kù)模式的最后一個(gè)要素是業(yè)務(wù)規(guī)則,它是對(duì)需要反映在數(shù)據(jù)庫(kù)和數(shù)據(jù)庫(kù)應(yīng)用程序中的業(yè)務(wù)活動(dòng)的約束。業(yè)務(wù)規(guī)則是模式的一個(gè)重要部分,因?yàn)樗麄冎付藷o(wú)論什么數(shù)據(jù)變化到達(dá)DBMS引擎,允許的數(shù)據(jù)值必須滿足的約束。不管無(wú)效的數(shù)據(jù)變化請(qǐng)求是來(lái)自窗體的用戶、查詢、修改請(qǐng)求還是應(yīng)用程序,DBMS都應(yīng)該拒絕。遺憾的是,不同的DBMS產(chǎn)品用不同的方法實(shí)施業(yè)務(wù)規(guī)則。在某些情況下,DBMS產(chǎn)品不具備實(shí)施必要業(yè)務(wù)規(guī)則的能力,必須以代碼形式把它們編入應(yīng)用程序。
第五章 倉(cāng)庫(kù)管理系統(tǒng)數(shù)據(jù)庫(kù)設(shè)計(jì)
5.1 數(shù)據(jù)庫(kù)概念設(shè)計(jì)
本系統(tǒng)涉及的實(shí)體有:管理員,商品,倉(cāng)庫(kù),供應(yīng)商。他們的實(shí)體及其屬性圖分別如下:
(1)貨物的實(shí)體及其屬性圖如圖5-1所示。
圖5-1 貨物實(shí)體及其屬性圖
(2)倉(cāng)庫(kù)的實(shí)體及其屬性圖如5-2所示。
圖5-2 倉(cāng)庫(kù)實(shí)體及其屬性圖
(3)管理員的實(shí)體及其屬性圖如圖5-3所示。
圖5-3 管理員的實(shí)體及其屬性圖
(4)供應(yīng)商的實(shí)體及其屬性圖如圖5-4所示。
圖5-4 供應(yīng)商實(shí)體及其屬性圖
5.2 倉(cāng)庫(kù)管理系統(tǒng)E-R圖
本系統(tǒng)E-R圖如圖5-5所示。
圖5-5 系統(tǒng)E-R圖
5.3 倉(cāng)庫(kù)管理系統(tǒng)數(shù)據(jù)表清單
表5-1 庫(kù)存管理系統(tǒng)數(shù)據(jù)表清單
數(shù)據(jù)表名稱
數(shù)據(jù)表用途
tb_BorrowGoods
保存貨物的借貨詳細(xì)信息
tb_CheckGoods
保存貨物的盤點(diǎn)詳細(xì)信息
tb_GoodsIn
保存貨物的入庫(kù)詳細(xì)信息
tb_GoodsInfo
保存貨物的基本信息
tb_GoodsOut
保存貨物的出庫(kù)詳細(xì)信息
tb_ProviderInfo
保存供應(yīng)商的基本信息
tb_ReturnGoods
保存貨物的還貨詳細(xì)信息
tb_StorehouseInfo
保存?zhèn)}庫(kù)的基本信息
tb_UserInfo
保存用戶的基本信息
表5-1
5.4 數(shù)據(jù)庫(kù)邏輯結(jié)構(gòu)設(shè)計(jì)
在上面的實(shí)體以及實(shí)體之間的關(guān)系的基礎(chǔ)上,形成數(shù)據(jù)庫(kù)中的表格以及各個(gè)表格之間的關(guān)系。
倉(cāng)庫(kù)管理系統(tǒng)數(shù)據(jù)庫(kù)中的各個(gè)表格的設(shè)計(jì)結(jié)果如下面的幾個(gè)表格所示。每個(gè)表格表示在數(shù)據(jù)庫(kù)中的一個(gè)表。
(1)tb_BorrowGoods表如表5-2
列名
數(shù)據(jù)類型
長(zhǎng)度
是否為主鍵
可否為空
GoodsBorrowID
int
YES
不能為空
GoodsName
varchar
50
NO
可為空
GoodsStorehouse
varchar
50
NO
可為空
GoodsProvider
varchar
50
NO
可為空
GoodsUnit
varchar
50
NO
可為空
BorrowNum
int
10
NO
可為空
BorrowDate
datetime
NO
可為空
BorrowPeople
varchar
50
NO
可為空
Handler
varchar
50
NO
可為空
Info
varchar
1000
NO
不能為空
表5-3
(2)tb_CheckGoods表如表5-3
列名
數(shù)據(jù)類型
長(zhǎng)度
是否為主鍵
可否為空
GoodsCheckID
int
YES
不能為空
GoodsBorrowID
int
NO
可為空
GoodsName
varchar
50
NO
可為空
GoodsStorehouse
varchar
50
NO
可為空
GoodsProvider
varchar
50
NO
可為空
InNum
int
NO
可為空
OutNum
int
NO
可為空
NeedNum
varchar
100
NO
可為空
CheckPeople
varchar
50
NO
可為空
CheckDate
datetime
NO
可為空
Info
varchar
100
NO
不能為空
表5-3
(3)tb_GoodsIn表如表5-4
列名
數(shù)據(jù)類型
長(zhǎng)度
是否為主鍵
可否為空
GoodsInID
int
10
YES
不能為空
GoodsName
varchar
50
NO
可為空
GoodsStorehouse
varchar
50
NO
可為空
GoodsProvider
varchar
50
NO
可為空
GoodsUnit
varchar
50
NO
可為空
GoodsNum
int
NO
可為空
GoodsPriceIn
money
NO
可為空
GoodsAllPrice
NO
可為空
GoodsInDate
datetime
NO
可為空
GoodsAdder
varchar
50
NO
可為空
GoodsInfo
text
NO
不能為空
表5-4
(4)tb_GoodsInfo表如表5-5
列名
數(shù)據(jù)類型
長(zhǎng)度
是否為主鍵
可否為空
GoodsID
int
10
YES
不能為空
GoodsName
varchar
50
NO
不能為空
GoodsStorehouse
varchar
50
NO
可為空
GoodsProvider
varchar
50
NO
可為空
GoodsUnit
varchar
50
NO
可為空
GoodsNum
int
NO
可為空
GoodsPriceIn
money
NO
可為空
GoodsPriceOut
money
NO
可為空
GoodsInfo
text
NO
可為空
AddDate
datetime
NO
可為空
AddUser
varchar
50
NO
可為空
GoodsLeast
int
NO
可為空
GoodsMost
int
NO
可為空
表5-5
(5)tb_GoodsOut表如表5-6
列名
數(shù)據(jù)類型
長(zhǎng)度
是否為主鍵
可否為空
GoodsOutID
int
YES
不能為空
GoodsName
varchar
50
NO
可為空
GoodsProvider
varchar
50
NO
可為空
GoodsUnit
varchar
50
NO
可為空
GoodsNum
int
NO
可為空
GoodsPriceOut
money
NO
可為空
GoodsAllPrice
NO
可為空
GoodsOutDate
datetime
NO
可為空
GoodsOutPeople
varchar
50
NO
可為空
GoodsOutCompany
varchar
50
NO
可為空
Handler
varchar
50
NO
可為空
GoodsInfo
text
NO
不能為空
表5-6
(6) tb_ProviderInfo表如表5-7
列名
數(shù)據(jù)類型
長(zhǎng)度
是否為主鍵
可否為空
ProviderID
int
YES
不能為空
ProviderName
varchar
50
NO
不能為空
ProviderManager
varchar
50
NO
可為空
ProviderPhone
varchar
50
NO
可為空
ProviderFax
varchar
50
NO
可為空
ProviderEmail
varchar
10
NO
可為空
ProviderAddress
varchar
1000
NO
可為空
ProviderInfo
text
NO
可為空
AddDate
datetime
NO
可為空
AddUser
varchar
1000
NO
可為空
表5-7
(7)tb_ReturnGoods表如表5-8
列名
數(shù)據(jù)類型
長(zhǎng)度
是否為主鍵
可否為空
ReturnGoodsID
int
YES
不能為空
GoodsName
varchar
50
NO
可為空
GoodsStorehouse
varchar
50
NO
可為空
GoodsProvider
varchar
50
NO
可為空
GoodsUnit
varchar
50
NO
可為空
ReturnNum
int
NO
可為空
ReturnDate
datetime
NO
可為空
ReturnPeople
varchar
50
NO
可為空
Handler
varchar
50
NO
可為空
Info
varchar
1000
NO
可為空
表5-8
(8) tb_StorehouseInfo表如表5-9
列名
數(shù)據(jù)類型
長(zhǎng)度
是否為主鍵
可否為空
StorehouseID
int
YES
不能為空
StorehouseName
varchar
50
NO
可為空
StorehouseManager
varchar
50
NO
可為空
StorehousePhone
varchar
50
NO
可為空
StorehouseInfo
text
NO
可為空
AddDate
datetime
NO
可為空
AddUser
varchar
50
NO
可為空
表5-9
(9)tb_UserInfo表如表5-10
列名
數(shù)據(jù)類型
長(zhǎng)度
是否為主鍵
可否為空
UserID
int
YES
不能為空
UserName
varchar
20
NO
不能為空
UserPwd
varchar
20
NO
不能為空
UserLevel
varchar
20
NO
不能為空
表5-10
第六章 界面展示及部分功能模塊主要代碼
6.1 模塊劃分
本系統(tǒng)模塊圖如圖6-1所示。
圖6-1 系統(tǒng)模塊圖
6.2 本程序登錄界面
出于對(duì)系統(tǒng)安全性的考慮,本系統(tǒng)設(shè)置了登錄模塊,只有持有效用戶名和密碼的用戶才能登錄該系統(tǒng)。此外,本系統(tǒng)設(shè)置了訪問權(quán)限,不同訪問權(quán)限的用戶進(jìn)入系統(tǒng)后能完成不同的操作,普通用戶只具有查詢的權(quán)限,管理員用戶可對(duì)普通用戶的信息進(jìn)行更改和入出庫(kù)等所有操作。具體的登錄頁(yè)面如圖6-2所示。
圖6-2系統(tǒng)登錄界面
主要實(shí)現(xiàn)代碼如下:
private void frmLogin_Load(object sender, EventArgs e)
{
dataoperate.ComboxDataBind("SELECT * FROM tb_UserInfo", "UserInfo", "UserName", cboxUserName);
}
private void cboxUserName_SelectedIndexChanged(object sender, EventArgs e)
{
try
{
string strCMD = "SELECT UserLevel FROM tb_UserInfo WHERE UserName=" + cboxUserName.Text + "";
SqlDataReader dr = dbcontrol.SqlExecuteReader(strCMD);
if (dr.Read())
{
strUserLevel = dr["UserLevel"].ToString();
lblUserLevel.Text = strUserLevel;
}
dr.Close();
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
}
private void btnLogin_Click(object sender, EventArgs e)
{
int iResult = dataoperate.Login(cboxUserName.Text.Trim(), txtPwd.Text.Trim());
if (iResult == 0)
{
MessageBox.Show("用戶名或密碼錯(cuò)誤!", "提示!", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
if (iResult == 1)
{
strUserName = cboxUserName.Text.Trim();
strUserPwd = txtPwd.Text.Trim();
frmMain frm = new frmMain();
frm.Show();
this.Hide();
}
}
6.3 本程序運(yùn)行后的效果
當(dāng)使用正確的用戶名和密碼登陸系統(tǒng)以后就進(jìn)入系統(tǒng)的主界面,在系統(tǒng)的主界面中可以選擇你要進(jìn)入的系統(tǒng)模塊,在系統(tǒng)的下面顯示了你登陸的用戶名,用戶權(quán)限以及登錄時(shí)間等。系統(tǒng)主界面如圖6-3所示。
圖6-3 系統(tǒng)主界面
6.4 選擇主窗體
選擇主窗體上的[貨物管理]或貨物管理頁(yè)面上的按鈕可以進(jìn)入入庫(kù)管理、出庫(kù)管理、借貨還貨和盤點(diǎn)管理功能窗體,如圖6-4所示。
圖6-4 貨物管理菜單界面
6.4.1 入庫(kù)管理窗體
入庫(kù)管理窗體中設(shè)置了入庫(kù)管理的基本信息,如圖6-5所示。
圖6-6 貨物入庫(kù)管理窗體
主要實(shí)現(xiàn)代碼如下:
private void frmGoodsIn_Load(object sender, EventArgs e)
{
ds = dbcontrol.GetDataSet("SELECT * FROM tb_GoodsIn", "GoodsIn");
if (ds.Tables[0].Rows.Count == 0)
{
btnDelete.Enabled = false;
}
else
{
btnDelete.Enabled = true;
dgvGoodsIn.DataSource = ds.Tables[0];
}
dataoperate.ComboxDataBind("SELECT ProviderName FROM tb_ProviderInfo",
"ProviderName", "ProviderName", cboxProvider);
dataoperate.ComboxDataBind("SELECT StorehouseName FROM tb_StorehouseInfo",
"StorehouseName", "StorehouseName", cboxStorehouse);
}
private void btnGoodsIn_Click(object sender, EventArgs e)
{
if (txtGoodsName.Text.Trim() == "")
{
MessageBox.Show("貨物名稱不能為空!", "提示!", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
else if (txtGoodsNum.Text.Trim() == "")
{
MessageBox.Show("貨物數(shù)量不能為空!", "提示!", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
else if (txtGoodsPriceIn.Text.Trim() == "")
{
MessageBox.Show("貨物進(jìn)價(jià)不能為空不能為空!", "提示!", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
else
{
try
{
dataoperate.GoodsIn(txtGoodsName.Text.Trim(),
cboxProvider.Text.Trim(), cboxStorehouse.Text.Trim(),
cboxGoodsUnit.Text.Trim(),
txtGoodsNum.Text.Trim(),
txtGoodsPriceIn.Text.Trim(),
DateTime.Now, txtGoodsAdder.Text.Trim(),
txtGoodsInfo.Text);
MessageBox.Show("入庫(kù)成功!", "提示!", MessageBoxButtons.OK, MessageBoxIcon.Information);
frmGoodsIn_Load(sender, e);
Clear();
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
}
}
6.4.2 出庫(kù)管理窗體
出庫(kù)管理窗體中設(shè)置了出庫(kù)管理的基本信息,如圖6-7所示。
圖6-8 貨物出庫(kù)管理窗體
主要實(shí)現(xiàn)代碼如下:
private void frmGoodsOut_Load(object sender, EventArgs e)
{
ds = dbcontrol.GetDataSet("SELECT * FROM tb_GoodsOut", "GoodsOut");
if (ds.Tables[0].Rows.Count == 0)
{
btnDelete.Enabled = false;
}
else
{
btnDelete.Enabled = true;
}
dgvGoodsOut.DataSource = ds.Tables[0];
dataoperate.ComboxDataBind("SELECT DISTINCT GoodsStorehouse FROM tb_GoodsInfo",
"Storehouse", "GoodsStorehouse", cboxStorehouse);
}
private void cboxStorehouse_SelectedIndexChanged(object sender, EventArgs e)
{
dataoperate.ComboxDataBind("SELECT DISTINCT GoodsProvider FROM tb_GoodsInfo WHERE GoodsStorehouse=" + cboxStorehouse.Text + "",
"ProviderInfo", "GoodsProvider", cboxProvider);
cboxGoodsName.Text = "";
}
private void cboxProvider_SelectedIndexChanged(object sender, EventArgs e)
{
dataoperate.ComboxDataBind("SELECT GoodsName FROM tb_GoodsInfo WHERE GoodsStorehouse=" + cboxStorehouse.Text + " AND GoodsProvider=" + cboxProvider.Text + "",
"GoodsName", "GoodsName", cboxGoodsName);
}
private void cboxGoodsName_SelectedIndexChanged(object sender, EventArgs e)
{
SqlDataReader dr = dbcontrol.SqlExecuteReader("SELECT * FROM tb_GoodsInfo WHERE GoodsStorehouse=" + cboxStorehouse.Text + " AND GoodsProvider=" + cboxProvider.Text + " AND GoodsName=" + cboxGoodsName.Text + "");
if (dr.Read())
{
cboxGoodsUnit.Text = dr["GoodsUnit"].ToString();
txtNumNow.Text = dr["GoodsNum"].ToString();
txtPriceOut.Text = dr["GoodsPriceOut"].ToString();
}
dr.Close();
}
6.4.3 借貨管理窗體
借貨管理窗體中設(shè)置了借貨管理的基本信息,如圖6-9所
圖6-9 借貨管理窗體
主要實(shí)現(xiàn)代碼如下:
private void btnBorrow_Click(object sender, EventArgs e)
{
if (txtBorrowNum.Text.Trim() == "")
{
MessageBox.Show("數(shù)量不能為空!", "提示!", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
else if (errorNum.GetError(txtBorrowNum).Equals("數(shù)量格式不正確!"))
{
MessageBox.Show("格式有誤!", "提示!", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
else
{
try
{
int iResult = da
收藏
- 資源描述:
-
專業(yè)綜合設(shè)計(jì)
系統(tǒng)名稱: 倉(cāng)庫(kù)管理系統(tǒng)
學(xué) 校: XXXXXXXXXXXXXXXX學(xué)院
系 別: 計(jì)算機(jī)科學(xué)與應(yīng)用系s
專 業(yè): 計(jì)算機(jī)科學(xué)與技術(shù)
姓 名: XXX
學(xué) 號(hào): XXXXXXXXX
指導(dǎo)教師: XX
日 期: 201X年X年X日
摘 要
隨著現(xiàn)代工業(yè)的發(fā)展,計(jì)算機(jī)信息管理系統(tǒng)越來(lái)越受到企業(yè)重視,庫(kù)存管理系統(tǒng)是典型的信息管理系統(tǒng)(MIS),其開發(fā)主要包括后臺(tái)數(shù)據(jù)庫(kù)的建立和維護(hù)以及前端應(yīng)用程序的開發(fā)兩個(gè)方面。對(duì)于前者要求建立一個(gè)數(shù)據(jù)一致性、完整性以及安全性好的庫(kù)。而對(duì)于后者則要求應(yīng)用程序功能完備,易使用等特點(diǎn)。
本設(shè)計(jì)采用Visual Studio 2005的開發(fā)環(huán)境,而后臺(tái)數(shù)據(jù)庫(kù)選用數(shù)據(jù)庫(kù)軟件SQL Server 2005,主要完成了庫(kù)存管理系統(tǒng)的需求分析、功能模塊的劃分、數(shù)據(jù)庫(kù)模式分析,并由此完成了數(shù)據(jù)庫(kù)結(jié)構(gòu)和應(yīng)用程序的實(shí)現(xiàn),系統(tǒng)基本實(shí)現(xiàn)了所需功能,界面友好,操作方便。
本系統(tǒng)主要是讓倉(cāng)庫(kù)的管理實(shí)現(xiàn)信息化、系統(tǒng)化,方便化,把計(jì)算機(jī)用于倉(cāng)庫(kù)管理中,這樣可以很大程度上提高管理者分析和決策的科學(xué)性,提高經(jīng)營(yíng)管理水平。
關(guān)鍵詞:倉(cāng)庫(kù)管理 Visual Studio 2005 SQL Server 2005
ABSTRACT
With the development of modern industry, the information management system of the computer is being paid attention to by enterprises. The stock management system is a typical MIS.It’s development mostly include the foundation and maintenance of the Database and the development of the client application programme.For the former we must eatablish a better database,which has well data consistency and data security.For the latter we must make the programme has self-contained function and easy to be use.
The design of the development environment using Visual studio 2005 , the database software is SQL Server 2005,mainly completed inventory management system needs analysis, the division of functional modules, the database model analysis, and thus completed the database structure and application implementation, The system basically achieves the required function, its interface is good, and is used well.
The system is designed to allow the management informationized and systematic, used computer in the catering management of supermarket, so it can improve the scientific of ana- lysis and decision-making,and enhance the management level.
Keywords: stock management Visual Studio 2005 SQL Server 2005
目 錄
第一章 緒論 1
1.1 倉(cāng)庫(kù)管理系統(tǒng) 1
1.2 倉(cāng)庫(kù)管理系統(tǒng)的研究背景與意義 1
第二章 開發(fā)工具簡(jiǎn)介 3
2.1 Visual Stdio 2005簡(jiǎn)介 3
2.2 SQL Server 2005簡(jiǎn)介 3
第三章 倉(cāng)庫(kù)管理系統(tǒng)分析 4
3.1 開發(fā)系統(tǒng)的目的 4
3.2 需求分析 4
3.3 可行性分析 5
3.3.1 技術(shù)可行性 5
3.3.2 經(jīng)濟(jì)可行性 5
3.3.3 管理可行性 5
3.3.4 社會(huì)可行性 6
3.5 系統(tǒng)流程圖 7
第四章 倉(cāng)庫(kù)管理系統(tǒng)數(shù)據(jù)庫(kù)分析 8
4.1 數(shù)據(jù)庫(kù)介紹 8
4.1.1 用戶數(shù)據(jù) 8
4.2 創(chuàng)建數(shù)據(jù)庫(kù) 9
第五章 倉(cāng)庫(kù)管理系統(tǒng)數(shù)據(jù)庫(kù)設(shè)計(jì) 10
5.1 數(shù)據(jù)庫(kù)概念設(shè)計(jì) 10
5.2 倉(cāng)庫(kù)管理系統(tǒng)E-R圖 11
5.3 倉(cāng)庫(kù)管理系統(tǒng)數(shù)據(jù)表清單 12
5.4 數(shù)據(jù)庫(kù)邏輯結(jié)構(gòu)設(shè)計(jì) 12
第六章 界面展示及部分功能模塊主要代碼 17
6.1 模塊劃分 17
6.2 本程序登錄界面 17
6.3 本程序運(yùn)行后的效果 18
6.4 選擇主窗體 19
6.4.1 入庫(kù)管理窗體 20
6.4.2 出庫(kù)管理窗體 21
6.4.3 借貨管理窗體 23
6.4.4 還貨管理窗體 24
6.4.5 盤點(diǎn)管理窗體 26
6.5 選擇主窗體 27
6.5.1 供應(yīng)商信息窗體 28
6.5.2 倉(cāng)庫(kù)管理窗體 29
6.5.3 貨物管理窗體 30
6.6 選擇主窗體 31
6.6.1 數(shù)據(jù)備份窗體 32
6.6.2 數(shù)據(jù)還原窗體 33
6.6.3 數(shù)據(jù)壓縮窗體 34
6.7 選擇主窗體 36
6.7.1 更改密碼窗體 36
6.7.2 用戶管理窗體 37
6.8 選擇主窗體 39
6.8.1 庫(kù)存查詢界面 40
第七章 軟件測(cè)試及維護(hù) 43
第八章 致謝 45
第九章 結(jié)論 46
參考文獻(xiàn) 47
IV
第一章 緒論
1.1 倉(cāng)庫(kù)管理系統(tǒng)
當(dāng)今時(shí)代是飛速發(fā)展的信息時(shí)代,在各行各業(yè)中離不開信息處理,計(jì)算機(jī)最大的好處在于利用它能夠進(jìn)行信息管理,使用計(jì)算機(jī)進(jìn)行信息控制,不僅提高了工作效率,而且大大的提高了其安全性,尤其針對(duì)復(fù)雜的信息管理,計(jì)算機(jī)能夠充分發(fā)揮它的優(yōu)越性。計(jì)算機(jī)進(jìn)行信息管理與信息管理系統(tǒng)的開發(fā)密切相關(guān),系統(tǒng)的開發(fā)是系統(tǒng)管理的前提。
倉(cāng)庫(kù)作為一種貨品資源的集散地,貨品的種類繁多,包含很多的信息數(shù)據(jù)的管理。據(jù)調(diào)查得知,以前倉(cāng)庫(kù)進(jìn)行信息管理的方式主要是基于文本、表格等介質(zhì)的手工處理,對(duì)于貨品的出入庫(kù)情況的統(tǒng)計(jì)和核實(shí)等往往采用對(duì)賬本的人工檢查,對(duì)管理者的管理權(quán)限等不受約束,任何人都可查看,這樣容易引起資料外泄。另外,數(shù)據(jù)信息處理工作量大,容易出錯(cuò),數(shù)據(jù)繁多,容易丟失,且不易查找??偟膩?lái)說,缺乏系統(tǒng)、規(guī)范的信息管理手段。而且,一般的存儲(chǔ)情況是記錄在賬本上的,倉(cāng)庫(kù)的工作人員和管理員也只是當(dāng)時(shí)記得比較清楚,時(shí)間一長(zhǎng),如果再要進(jìn)行查詢,就得在眾多的資料中翻閱查找了,這樣造成費(fèi)時(shí)、費(fèi)力,如要對(duì)很長(zhǎng)時(shí)間以前的貨品進(jìn)行更改就更加困難了。因此,很有必要建立一個(gè)庫(kù)存管理系統(tǒng),使貨品管理工作規(guī)范化、系統(tǒng)化、程序化。提高信息處理的速度和準(zhǔn)確性。
1.2 倉(cāng)庫(kù)管理系統(tǒng)的研究背景與意義
眾所周知,倉(cāng)庫(kù)管理是一種既麻煩又單調(diào)的工作,每天都是重復(fù)記錄一些貨物的存入與取出,而且貨物的種類繁多,存取有很大的隨機(jī)性,這樣為工作人員帶來(lái)了很大的不便,在操作過程中,由于人為的計(jì)算出錯(cuò)率很高,一旦出錯(cuò)改正也很困難,這樣簡(jiǎn)單繁重的工作要很多人來(lái)做,為經(jīng)營(yíng)者增加了很多成本,所以開發(fā)一個(gè)可行的倉(cāng)庫(kù)管理系統(tǒng)是十分必要的。
隨著我國(guó)經(jīng)濟(jì)的飛速發(fā)展,各種類型規(guī)模的公司企業(yè)迅速崛起,許多從事生產(chǎn)和經(jīng)營(yíng)管理的企業(yè)都有自己生產(chǎn)和銷售的產(chǎn)品,而這些產(chǎn)品都需要儲(chǔ)存在倉(cāng)庫(kù)中,對(duì)于每個(gè)企業(yè)來(lái)說,隨著企業(yè)規(guī)模的不斷擴(kuò)大,產(chǎn)品數(shù)量的急劇增加,所生產(chǎn)產(chǎn)品的種類也會(huì)不斷地更新與發(fā)展,有關(guān)產(chǎn)品的各種信息量也會(huì)成倍增長(zhǎng)。面對(duì)龐大的產(chǎn)品信息量,如何有效地管理庫(kù)存產(chǎn)品,對(duì)這些企業(yè)來(lái)說是非常重要的,庫(kù)存管理的重點(diǎn)是銷售信息能否及時(shí)反饋,從而確保企業(yè)運(yùn)行效益。而庫(kù)存管理又涉及入庫(kù)、出庫(kù)的產(chǎn)品、經(jīng)辦人員及客戶等方方面面的因素,如何管理這些信息數(shù)據(jù),是一項(xiàng)復(fù)雜的系統(tǒng)工程,充分考驗(yàn)著倉(cāng)庫(kù)管理員的工作能力,工作量的繁重是可想而知的,所以這就需要由倉(cāng)庫(kù)管理系統(tǒng)來(lái)提高庫(kù)存管理工作的效率,這對(duì)信息的規(guī)范管理、科學(xué)統(tǒng)計(jì)和快速查詢,減少管理方面的工作量,同時(shí)對(duì)于調(diào)動(dòng)廣大員工的工作積極性,提高企業(yè)的生產(chǎn)效率,都具有十分重要的現(xiàn)實(shí)意義。
第二章 開發(fā)工具簡(jiǎn)介
2.1 Visual Stdio 2005簡(jiǎn)介
開發(fā)這個(gè)系統(tǒng)使用Visual Stdio 2005工具來(lái)開發(fā), Visual Stdio 2005是當(dāng)前最流行的一款程序開發(fā)工具,利用它可以開發(fā)功能強(qiáng)大的、運(yùn)行在Windows平臺(tái)上的、能夠操作數(shù)據(jù)庫(kù)的應(yīng)用系統(tǒng),因此能夠適應(yīng)我們開發(fā)本系統(tǒng)的要求,并且簡(jiǎn)單易用,實(shí)現(xiàn)功能的代碼量比其他語(yǔ)言減少許多,這樣就縮短了軟件開發(fā)周期,大大節(jié)約了軟件開發(fā)成本。
2.2 SQL Server 2005簡(jiǎn)介
SQL Server 2005 是一個(gè)全面的數(shù)據(jù)庫(kù)平臺(tái),使用集成的商業(yè)智能 (BI) 工具提供了企業(yè)級(jí)的數(shù)據(jù)管理,SQL Server 2005 數(shù)據(jù)庫(kù)引擎為關(guān)系型數(shù)據(jù)和結(jié)構(gòu)化數(shù)據(jù)提供了更安全可靠的存儲(chǔ)功能。SQL Server 2005 中包含了非常豐富的新特性:通過提供一個(gè)更安全、可靠和高效的數(shù)據(jù)管理平臺(tái),增強(qiáng)企業(yè)組織中用戶的管理能力,大幅提升IT管理效率并降低運(yùn)維風(fēng)險(xiǎn)和成本;通過提供先進(jìn)的商業(yè)智能平臺(tái)滿足眾多客戶對(duì)業(yè)務(wù)的實(shí)時(shí)統(tǒng)計(jì)分析、監(jiān)控預(yù)測(cè)等多種復(fù)雜管理需求,推動(dòng)企業(yè)管理信息化建設(shè)和業(yè)務(wù)發(fā)展;同時(shí),SQL Server 2005將提供一個(gè)極具擴(kuò)展性和靈活性的開發(fā)平臺(tái),實(shí)現(xiàn)Internet數(shù)據(jù)業(yè)務(wù)互聯(lián)。
第三章 倉(cāng)庫(kù)管理系統(tǒng)分析
3.1 開發(fā)系統(tǒng)的目的
開發(fā)倉(cāng)庫(kù)管理系統(tǒng),主要為減輕倉(cāng)庫(kù)管理人員的負(fù)擔(dān),使貨物的存入記錄與取出記錄相對(duì)完善,便于貨物的增加與減少,降低出錯(cuò)率,使管理更加合理、科學(xué),也為經(jīng)營(yíng)者節(jié)省開支。本系統(tǒng)完面考慮了倉(cāng)庫(kù)在管理中要解決的所有需求,最終向用戶提供一套方便可行的系統(tǒng),該系統(tǒng)具備以下特征:配置必要的數(shù)據(jù)庫(kù)和應(yīng)用服務(wù)程序,提供查詢、統(tǒng)計(jì)貨物的種類、數(shù)量及所屬公司等所有信息的功能,操作人員使用的界面要清晰、美觀,布局合理,內(nèi)容盡量簡(jiǎn)單明了,提供的信息詳細(xì)全面??蛻舳顺绦蛞蟀踩愿?,可靠性高。
3.2 需求分析
市場(chǎng)經(jīng)濟(jì)的一個(gè)重要特征,就是生產(chǎn)的相對(duì)過剩和產(chǎn)品的相對(duì)過剩。它決定了這是一個(gè)買方市場(chǎng)。對(duì)企業(yè)來(lái)說,庫(kù)存的增加或積壓,無(wú)論是原材料、半成品或制成品,都意味著企業(yè)運(yùn)作處于一種不良的狀態(tài),都是一種直接的或潛在的損失。大量的庫(kù)存擠占了企業(yè)的有限資金,使得資金流速減緩,現(xiàn)金流發(fā)生困難,甚至導(dǎo)致資金緊張,影響企業(yè)的正常運(yùn)作。此外,大量的庫(kù)存增加了保管與倉(cāng)儲(chǔ)的壓力,占用了相當(dāng)?shù)娜肆臀锪?,使得企業(yè)負(fù)擔(dān)加重。凡此種種,一直困擾著企業(yè)的生產(chǎn)經(jīng)營(yíng)管理活動(dòng),影響企業(yè)經(jīng)濟(jì)效益的實(shí)現(xiàn)。顯而易見,切實(shí)而有效地控制庫(kù)存,是擺在眾多企業(yè)面前的當(dāng)務(wù)之急,也是緩解企業(yè)經(jīng)濟(jì)壓力、減負(fù)增效的重要途徑。
需求分析是軟件定義時(shí)期的最后一個(gè)階段,它的基本任務(wù)是準(zhǔn)確地回答“系統(tǒng)必須做什么”這個(gè)問題,是對(duì)目標(biāo)系統(tǒng)提出完整、準(zhǔn)確、清晰、具體的要求。需求分析的結(jié)果是系統(tǒng)開發(fā)的基礎(chǔ),關(guān)系到工程的成敗和軟件產(chǎn)品的質(zhì)量。因此,必須用行之有效的方法對(duì)軟件需求進(jìn)行嚴(yán)格的審查驗(yàn)證。
軟件需求分析過程是整個(gè)系統(tǒng)開發(fā)的重要階段,分析的成功與否,決定著整個(gè)系統(tǒng)功能的完善性以及穩(wěn)定性。在該階段分析人員需要確定整個(gè)產(chǎn)品的功能要求,并將提供一種可轉(zhuǎn)化為數(shù)據(jù)設(shè)計(jì)、結(jié)構(gòu)設(shè)計(jì)和過程設(shè)計(jì)的數(shù)據(jù)與功能表示。在軟件完成后,需求分析階段研究的對(duì)象是軟件項(xiàng)目的用戶要求。
3.3 可行性分析
可行性研究的目的就是用最小的代價(jià)在盡可能短的時(shí)間內(nèi)確定問題是否能夠解決。要達(dá)到這個(gè)目的,必須分析幾種主要的可能解法的利弊,從而判斷原定的系統(tǒng)規(guī)模和目標(biāo)是 的效益是否達(dá)到值得投資開發(fā)這個(gè)系統(tǒng)的程度。一般來(lái)說,可行性分析應(yīng)從經(jīng)濟(jì)可行性、技術(shù)可行性、經(jīng)濟(jì)可行性、操作可行性、社會(huì)可行性等方面進(jìn)行研究。本系統(tǒng)的可行性分析如下:
3.3.1 技術(shù)可行性
隨著國(guó)內(nèi)軟件開發(fā)的日益發(fā)展壯大,各種中小企事業(yè)單位已具備獨(dú)立開發(fā)各種類型的軟件的能力,能夠滿足不同行業(yè)的特別的需求,現(xiàn)在,市場(chǎng)上可以選購(gòu)的應(yīng)用開發(fā)產(chǎn)品很多,流行的也有數(shù)十種。此外,從開發(fā)人員的水平考慮,作為計(jì)算機(jī)科學(xué)與技術(shù)專業(yè)畢業(yè)的學(xué)生,大學(xué)四年所積累的專業(yè)知識(shí)使我們從一定程度上具備了開發(fā)一個(gè)小型系統(tǒng)的能力,而且學(xué)校現(xiàn)有的計(jì)算機(jī)設(shè)備也完全能夠滿足開發(fā)的需要。本系統(tǒng)主要管理的是貨物的入庫(kù),出庫(kù),查詢相關(guān)的一些信息等,采用C#和Microsoft Visual Studio作為前臺(tái)用戶界面的開發(fā)語(yǔ)言和工具,而后臺(tái)的數(shù)據(jù)庫(kù)采用微軟的SQL Server 2005。由于主要采用數(shù)據(jù)庫(kù)來(lái)進(jìn)行管理,實(shí)現(xiàn)起來(lái)比較簡(jiǎn)單,從技術(shù)上來(lái)說是完全可行的。
3.3.2 經(jīng)濟(jì)可行性
對(duì)于整個(gè)系統(tǒng)而言,在系統(tǒng)未運(yùn)行之前,初期投資比較大,花費(fèi)相當(dāng)而言比較多。各部門必須配置電腦、服務(wù)器、打印機(jī)、傳真機(jī)及相關(guān)的網(wǎng)絡(luò)設(shè)備,但是在整個(gè)系統(tǒng)投入運(yùn)行之后,將會(huì)給該企業(yè)帶來(lái)前所未有的方便和快捷,減少不必要的中間環(huán)節(jié)以及不必要的開支,而且可以給其帶來(lái)更大的利潤(rùn)??傊?,這個(gè)系統(tǒng)的經(jīng)濟(jì)效益遠(yuǎn)遠(yuǎn)大于開發(fā)成本,而同時(shí)又減少了數(shù)據(jù)的流通環(huán)節(jié),不必要花費(fèi)那么多的時(shí)間,也就是說最重要的就是提高了效率,而又保證了各項(xiàng)數(shù)據(jù)的準(zhǔn)確性,也避免了工作人員的流動(dòng)造成的收據(jù)丟失等問題,適應(yīng)了當(dāng)前的發(fā)展形勢(shì)。
3.3.3 管理可行性
傳統(tǒng)的庫(kù)存管理系統(tǒng),一般有兩種方式:一是手工管理,這種方式應(yīng)用最傳統(tǒng)的“筆紙操作系統(tǒng)”,將庫(kù)存的貨物信息、銷售信息、廠商信息管理及單據(jù)管理等均以純手工的形式進(jìn)行,將信息以表格文件的表現(xiàn)形式記錄在紙上,再進(jìn)行統(tǒng)一保存。這種方式雖然在簡(jiǎn)單信息查詢時(shí)會(huì)有一定的方便,但是存在著更多的不便:信息保存時(shí)間和條件很受限制、容易被損壞、信息查詢不便、信息傳達(dá)容易造成失誤等。另一種常見的信息管理方法是應(yīng)用管理系統(tǒng),本系統(tǒng)就是一款做的相對(duì)到位的庫(kù)存管理系統(tǒng),隨著時(shí)代的發(fā)展,人員素質(zhì)已逐步提高,庫(kù)存管理人員已經(jīng)有豐富的信息管理經(jīng)驗(yàn),不論是對(duì)于電腦系統(tǒng)的基本操作還是對(duì)于系統(tǒng)的維護(hù)都有了一定的基礎(chǔ),同時(shí)還可以配置專業(yè)的電腦維護(hù)人員來(lái)維護(hù)電腦不必?fù)?dān)心電腦故障問題。
3.3.4 社會(huì)可行性
該系統(tǒng)是作為畢業(yè)設(shè)計(jì),不會(huì)對(duì)社會(huì)造成嚴(yán)重影響,也不用考慮到版權(quán)、法律等社會(huì)因素,所以在社會(huì)方面也是可行的。
3.4系統(tǒng)功能描述及系統(tǒng)安全性
一、庫(kù)存管理系統(tǒng)是一套對(duì)貨品入庫(kù)、出庫(kù)、庫(kù)存進(jìn)行全面管理的系統(tǒng),在設(shè)計(jì)該系統(tǒng)時(shí),應(yīng)盡可能便于用戶管理和操作。系統(tǒng)在實(shí)現(xiàn)上應(yīng)該具有如下功能:
(1)系統(tǒng)要求用戶必須輸入正確的用戶名和密碼才能進(jìn)入系統(tǒng)。
(2)系統(tǒng)能實(shí)現(xiàn)貨物的入,出庫(kù)功能。
(3)系統(tǒng)提供查詢現(xiàn)在庫(kù)存的情況,及入庫(kù)、出庫(kù)和貨物年統(tǒng)計(jì)等的記錄。
(4)系統(tǒng)提供管理員設(shè)置倉(cāng)庫(kù)信息和修改貨物信息等。
(5)系統(tǒng)提供管理員增加、刪除、修改用戶賬戶的功能。
二、由于庫(kù)存管理系統(tǒng)包含比較重要的信息,因此,在系統(tǒng)設(shè)計(jì)時(shí)除了注重用戶的需求,還要保證系統(tǒng)的安全性和一致性,該系統(tǒng)中管理權(quán)限上應(yīng)當(dāng)進(jìn)行嚴(yán)格控制,體現(xiàn)如下:
(1)安全性:本系統(tǒng)中共分為三類不同的用戶,分別具有不同的權(quán)限。要想對(duì)該庫(kù)存管理系統(tǒng)進(jìn)行操作就應(yīng)當(dāng)具有某些操作權(quán)限,沒有權(quán)限的用戶將不能通過任何渠道來(lái)登錄該系統(tǒng),查看該系統(tǒng)的任何信息和數(shù)據(jù),以確保系統(tǒng)的嚴(yán)密性和安全性,系統(tǒng)用戶分為管理員用戶和普通用戶,管理員用戶可對(duì)普通用戶信息進(jìn)行增、刪、改,普通用戶則只能查詢。在具體實(shí)現(xiàn)時(shí)還應(yīng)為系統(tǒng)管理員和普通用戶設(shè)定不同的操作權(quán)限,系統(tǒng)管理員應(yīng)當(dāng)可以操作系統(tǒng)的所有模塊,普通用戶對(duì)于貨物管理和基本檔案管理模塊是無(wú)權(quán)使用的。
(2)一致性:系統(tǒng)的數(shù)據(jù)要保證一致性、準(zhǔn)確性,當(dāng)某一數(shù)據(jù)庫(kù)中記錄發(fā)生改變時(shí),與之相關(guān)聯(lián)的數(shù)據(jù)庫(kù)也隨之變化。
3.5 系統(tǒng)流程圖
本系統(tǒng)流程圖如圖3-1所示。
圖3-1 系統(tǒng)流程圖
第四章 倉(cāng)庫(kù)管理系統(tǒng)數(shù)據(jù)庫(kù)分析
4.1 數(shù)據(jù)庫(kù)介紹
數(shù)據(jù)庫(kù)在一個(gè)信息管理系統(tǒng)中占有非常重要的地位,數(shù)據(jù)庫(kù)結(jié)構(gòu)設(shè)計(jì)的好壞將直接對(duì)應(yīng)用系統(tǒng)的效率以及實(shí)現(xiàn)的效果產(chǎn)生影響。合理的數(shù)據(jù)庫(kù)結(jié)構(gòu)設(shè)計(jì)可以提高數(shù)據(jù)存儲(chǔ)的效率,保證數(shù)據(jù)的完整和一致。同時(shí),合理的數(shù)據(jù)庫(kù)結(jié)構(gòu)也將有利于程序的實(shí)現(xiàn)。設(shè)計(jì)數(shù)據(jù)庫(kù)時(shí)應(yīng)該首先充分了解用戶各個(gè)方面的需求,包括現(xiàn)有的以及將來(lái)可能增加的需求。
數(shù)據(jù)庫(kù)設(shè)計(jì)是在既定(本系統(tǒng)使用SQL Server)的數(shù)據(jù)庫(kù)管理系統(tǒng)基礎(chǔ)之上建立數(shù)據(jù)庫(kù)的過程。其過程是將現(xiàn)實(shí)存在的數(shù)據(jù)及其應(yīng)用處理關(guān)系進(jìn)行抽象,從而形成數(shù)據(jù)庫(kù)結(jié)構(gòu)。數(shù)據(jù)庫(kù)是數(shù)據(jù)庫(kù)應(yīng)用程序的核心,數(shù)據(jù)庫(kù)設(shè)計(jì)是建立一個(gè)應(yīng)用程序最重要的一步。一個(gè)好的數(shù)據(jù)庫(kù)結(jié)構(gòu)和文件設(shè)計(jì)可以使系統(tǒng)在已有的條件下具有處理速度快,占用存儲(chǔ)空間少,操作處理過程簡(jiǎn)單,查找容易,系統(tǒng)開銷和費(fèi)用低等特點(diǎn)。具體實(shí)現(xiàn)時(shí),應(yīng)首先明確用戶對(duì)數(shù)據(jù)的需求,在此基礎(chǔ)上,建立數(shù)據(jù)庫(kù)的概念模型,概念模型主要是用來(lái)反映用戶的現(xiàn)實(shí)環(huán)境和需求,它獨(dú)立于具體的數(shù)據(jù)庫(kù)管理系統(tǒng),并且與數(shù)據(jù)庫(kù)怎樣實(shí)現(xiàn)無(wú)關(guān),建立概念模型的主要工具為實(shí)體關(guān)系(E-R)圖,在建立數(shù)據(jù)庫(kù)概念模型之后,要真正實(shí)現(xiàn)與數(shù)據(jù)庫(kù)管理系統(tǒng)的結(jié)合,即能夠由既定的數(shù)據(jù)庫(kù)管理系統(tǒng)所支持,還必須進(jìn)行邏輯結(jié)構(gòu)的設(shè)計(jì),在邏輯設(shè)計(jì)階段,主要完成建立數(shù)據(jù)庫(kù)的邏輯模型,并解決數(shù)據(jù)的完整性、一致性、安全性和有效性等問題;最后一個(gè)階段是數(shù)據(jù)庫(kù)的物理結(jié)構(gòu)設(shè)計(jì),其任務(wù)是為系統(tǒng)邏輯結(jié)構(gòu)模型確定合理的存儲(chǔ)結(jié)構(gòu)、存取方法、以及數(shù)據(jù)表示和數(shù)據(jù)存儲(chǔ)空間分配等內(nèi)容,從而得到具體的數(shù)據(jù)庫(kù)物理結(jié)構(gòu)。
數(shù)據(jù)庫(kù)由DBMS(數(shù)據(jù)庫(kù)管理系統(tǒng))處理,DBMS則由開發(fā)人員和用戶通過應(yīng)用程序直接或間接地使用。它主要包括四個(gè)要素:用戶數(shù)據(jù)、元數(shù)據(jù)、索引和應(yīng)用元數(shù)據(jù)。
4.1.1 用戶數(shù)據(jù)
目前,大多數(shù)主流數(shù)據(jù)庫(kù)管理系統(tǒng)把用戶數(shù)據(jù)表示為關(guān)系。現(xiàn)在把關(guān)系看作數(shù)據(jù)表,表的列包含域或?qū)傩?,表的行包含?duì)應(yīng)業(yè)務(wù)環(huán)境中的實(shí)體的記錄。并非所有的關(guān)系都同樣符合要求,有些關(guān)系比其它關(guān)系更結(jié)構(gòu)化一些。
(1)元數(shù)據(jù)
數(shù)據(jù)庫(kù)是自描述的,這就意味著它自身包含了它的結(jié)構(gòu)的描述,這種結(jié)構(gòu)的描述稱作元數(shù)據(jù)。因?yàn)镈BMS產(chǎn)品是用來(lái)存儲(chǔ)和操縱表的,所以大多數(shù)產(chǎn)品把元數(shù)據(jù)以表的形式存儲(chǔ),有時(shí)稱作系統(tǒng)表。這些系統(tǒng)表存儲(chǔ)了數(shù)據(jù)庫(kù)中表的情況,指出每一個(gè)表中有多少列,那一列是主關(guān)鍵字,每一列的數(shù)據(jù)類型的描述,它也存儲(chǔ)索引、關(guān)鍵字、規(guī)則和數(shù)據(jù)庫(kù)結(jié)構(gòu)的其他部分。
在表中存儲(chǔ)元數(shù)據(jù)不僅對(duì)DBMS是有效的,對(duì)用戶也是方便的,因?yàn)樗麄兛梢允褂门c查詢用戶數(shù)據(jù)同樣的查詢工具來(lái)查詢?cè)獢?shù)據(jù)。
(2)索引
第三種類型的數(shù)據(jù)改進(jìn)了數(shù)據(jù)庫(kù)的性能和可訪問性,這種數(shù)據(jù)經(jīng)常稱作開銷數(shù)據(jù),盡管有時(shí)也采用其他類型的數(shù)據(jù)結(jié)構(gòu),如鏈表,但它主要還是索引。索引可以用來(lái)排序和快速訪問數(shù)據(jù)。
(3)應(yīng)用元數(shù)據(jù)
存儲(chǔ)在數(shù)據(jù)庫(kù)中的第四種數(shù)據(jù)是應(yīng)用元數(shù)據(jù),它用來(lái)存儲(chǔ)用戶窗體、報(bào)表、查詢和其他形式的查詢組件。并非所有的DBMS都支持應(yīng)用組件,支持組件的DBMS也不一定把全部組件的結(jié)構(gòu)作為應(yīng)用元數(shù)據(jù)存儲(chǔ)在數(shù)據(jù)庫(kù)中。然而,大多數(shù)現(xiàn)代的DBMS產(chǎn)品存儲(chǔ)這種數(shù)據(jù)作為數(shù)據(jù)庫(kù)的一部分。一般來(lái)說,數(shù)據(jù)庫(kù)開發(fā)人員和用戶都不直接訪問應(yīng)用元數(shù)據(jù),相反,他們通過DBMS中的工具來(lái)處理這些數(shù)據(jù)。
4.2 創(chuàng)建數(shù)據(jù)庫(kù)
數(shù)據(jù)庫(kù)模式定義了數(shù)據(jù)庫(kù)的結(jié)構(gòu)、表、關(guān)系、域和業(yè)務(wù)規(guī)則。數(shù)據(jù)庫(kù)模式是一種設(shè)計(jì),數(shù)據(jù)庫(kù)的應(yīng)用正是建立在此基礎(chǔ)上的。
域是一列可能擁有的值的集合。必須為每一個(gè)表的每一列確定域。除了數(shù)據(jù)的物理格式外,還需要確定是否有些域?qū)Ρ韥?lái)說是唯一的。
數(shù)據(jù)庫(kù)模式的最后一個(gè)要素是業(yè)務(wù)規(guī)則,它是對(duì)需要反映在數(shù)據(jù)庫(kù)和數(shù)據(jù)庫(kù)應(yīng)用程序中的業(yè)務(wù)活動(dòng)的約束。業(yè)務(wù)規(guī)則是模式的一個(gè)重要部分,因?yàn)樗麄冎付藷o(wú)論什么數(shù)據(jù)變化到達(dá)DBMS引擎,允許的數(shù)據(jù)值必須滿足的約束。不管無(wú)效的數(shù)據(jù)變化請(qǐng)求是來(lái)自窗體的用戶、查詢、修改請(qǐng)求還是應(yīng)用程序,DBMS都應(yīng)該拒絕。遺憾的是,不同的DBMS產(chǎn)品用不同的方法實(shí)施業(yè)務(wù)規(guī)則。在某些情況下,DBMS產(chǎn)品不具備實(shí)施必要業(yè)務(wù)規(guī)則的能力,必須以代碼形式把它們編入應(yīng)用程序。
第五章 倉(cāng)庫(kù)管理系統(tǒng)數(shù)據(jù)庫(kù)設(shè)計(jì)
5.1 數(shù)據(jù)庫(kù)概念設(shè)計(jì)
本系統(tǒng)涉及的實(shí)體有:管理員,商品,倉(cāng)庫(kù),供應(yīng)商。他們的實(shí)體及其屬性圖分別如下:
(1)貨物的實(shí)體及其屬性圖如圖5-1所示。
圖5-1 貨物實(shí)體及其屬性圖
(2)倉(cāng)庫(kù)的實(shí)體及其屬性圖如5-2所示。
圖5-2 倉(cāng)庫(kù)實(shí)體及其屬性圖
(3)管理員的實(shí)體及其屬性圖如圖5-3所示。
圖5-3 管理員的實(shí)體及其屬性圖
(4)供應(yīng)商的實(shí)體及其屬性圖如圖5-4所示。
圖5-4 供應(yīng)商實(shí)體及其屬性圖
5.2 倉(cāng)庫(kù)管理系統(tǒng)E-R圖
本系統(tǒng)E-R圖如圖5-5所示。
圖5-5 系統(tǒng)E-R圖
5.3 倉(cāng)庫(kù)管理系統(tǒng)數(shù)據(jù)表清單
表5-1 庫(kù)存管理系統(tǒng)數(shù)據(jù)表清單
數(shù)據(jù)表名稱
數(shù)據(jù)表用途
tb_BorrowGoods
保存貨物的借貨詳細(xì)信息
tb_CheckGoods
保存貨物的盤點(diǎn)詳細(xì)信息
tb_GoodsIn
保存貨物的入庫(kù)詳細(xì)信息
tb_GoodsInfo
保存貨物的基本信息
tb_GoodsOut
保存貨物的出庫(kù)詳細(xì)信息
tb_ProviderInfo
保存供應(yīng)商的基本信息
tb_ReturnGoods
保存貨物的還貨詳細(xì)信息
tb_StorehouseInfo
保存?zhèn)}庫(kù)的基本信息
tb_UserInfo
保存用戶的基本信息
表5-1
5.4 數(shù)據(jù)庫(kù)邏輯結(jié)構(gòu)設(shè)計(jì)
在上面的實(shí)體以及實(shí)體之間的關(guān)系的基礎(chǔ)上,形成數(shù)據(jù)庫(kù)中的表格以及各個(gè)表格之間的關(guān)系。
倉(cāng)庫(kù)管理系統(tǒng)數(shù)據(jù)庫(kù)中的各個(gè)表格的設(shè)計(jì)結(jié)果如下面的幾個(gè)表格所示。每個(gè)表格表示在數(shù)據(jù)庫(kù)中的一個(gè)表。
(1)tb_BorrowGoods表如表5-2
列名
數(shù)據(jù)類型
長(zhǎng)度
是否為主鍵
可否為空
GoodsBorrowID
int
YES
不能為空
GoodsName
varchar
50
NO
可為空
GoodsStorehouse
varchar
50
NO
可為空
GoodsProvider
varchar
50
NO
可為空
GoodsUnit
varchar
50
NO
可為空
BorrowNum
int
10
NO
可為空
BorrowDate
datetime
NO
可為空
BorrowPeople
varchar
50
NO
可為空
Handler
varchar
50
NO
可為空
Info
varchar
1000
NO
不能為空
表5-3
(2)tb_CheckGoods表如表5-3
列名
數(shù)據(jù)類型
長(zhǎng)度
是否為主鍵
可否為空
GoodsCheckID
int
YES
不能為空
GoodsBorrowID
int
NO
可為空
GoodsName
varchar
50
NO
可為空
GoodsStorehouse
varchar
50
NO
可為空
GoodsProvider
varchar
50
NO
可為空
InNum
int
NO
可為空
OutNum
int
NO
可為空
NeedNum
varchar
100
NO
可為空
CheckPeople
varchar
50
NO
可為空
CheckDate
datetime
NO
可為空
Info
varchar
100
NO
不能為空
表5-3
(3)tb_GoodsIn表如表5-4
列名
數(shù)據(jù)類型
長(zhǎng)度
是否為主鍵
可否為空
GoodsInID
int
10
YES
不能為空
GoodsName
varchar
50
NO
可為空
GoodsStorehouse
varchar
50
NO
可為空
GoodsProvider
varchar
50
NO
可為空
GoodsUnit
varchar
50
NO
可為空
GoodsNum
int
NO
可為空
GoodsPriceIn
money
NO
可為空
GoodsAllPrice
NO
可為空
GoodsInDate
datetime
NO
可為空
GoodsAdder
varchar
50
NO
可為空
GoodsInfo
text
NO
不能為空
表5-4
(4)tb_GoodsInfo表如表5-5
列名
數(shù)據(jù)類型
長(zhǎng)度
是否為主鍵
可否為空
GoodsID
int
10
YES
不能為空
GoodsName
varchar
50
NO
不能為空
GoodsStorehouse
varchar
50
NO
可為空
GoodsProvider
varchar
50
NO
可為空
GoodsUnit
varchar
50
NO
可為空
GoodsNum
int
NO
可為空
GoodsPriceIn
money
NO
可為空
GoodsPriceOut
money
NO
可為空
GoodsInfo
text
NO
可為空
AddDate
datetime
NO
可為空
AddUser
varchar
50
NO
可為空
GoodsLeast
int
NO
可為空
GoodsMost
int
NO
可為空
表5-5
(5)tb_GoodsOut表如表5-6
列名
數(shù)據(jù)類型
長(zhǎng)度
是否為主鍵
可否為空
GoodsOutID
int
YES
不能為空
GoodsName
varchar
50
NO
可為空
GoodsProvider
varchar
50
NO
可為空
GoodsUnit
varchar
50
NO
可為空
GoodsNum
int
NO
可為空
GoodsPriceOut
money
NO
可為空
GoodsAllPrice
NO
可為空
GoodsOutDate
datetime
NO
可為空
GoodsOutPeople
varchar
50
NO
可為空
GoodsOutCompany
varchar
50
NO
可為空
Handler
varchar
50
NO
可為空
GoodsInfo
text
NO
不能為空
表5-6
(6) tb_ProviderInfo表如表5-7
列名
數(shù)據(jù)類型
長(zhǎng)度
是否為主鍵
可否為空
ProviderID
int
YES
不能為空
ProviderName
varchar
50
NO
不能為空
ProviderManager
varchar
50
NO
可為空
ProviderPhone
varchar
50
NO
可為空
ProviderFax
varchar
50
NO
可為空
ProviderEmail
varchar
10
NO
可為空
ProviderAddress
varchar
1000
NO
可為空
ProviderInfo
text
NO
可為空
AddDate
datetime
NO
可為空
AddUser
varchar
1000
NO
可為空
表5-7
(7)tb_ReturnGoods表如表5-8
列名
數(shù)據(jù)類型
長(zhǎng)度
是否為主鍵
可否為空
ReturnGoodsID
int
YES
不能為空
GoodsName
varchar
50
NO
可為空
GoodsStorehouse
varchar
50
NO
可為空
GoodsProvider
varchar
50
NO
可為空
GoodsUnit
varchar
50
NO
可為空
ReturnNum
int
NO
可為空
ReturnDate
datetime
NO
可為空
ReturnPeople
varchar
50
NO
可為空
Handler
varchar
50
NO
可為空
Info
varchar
1000
NO
可為空
表5-8
(8) tb_StorehouseInfo表如表5-9
列名
數(shù)據(jù)類型
長(zhǎng)度
是否為主鍵
可否為空
StorehouseID
int
YES
不能為空
StorehouseName
varchar
50
NO
可為空
StorehouseManager
varchar
50
NO
可為空
StorehousePhone
varchar
50
NO
可為空
StorehouseInfo
text
NO
可為空
AddDate
datetime
NO
可為空
AddUser
varchar
50
NO
可為空
表5-9
(9)tb_UserInfo表如表5-10
列名
數(shù)據(jù)類型
長(zhǎng)度
是否為主鍵
可否為空
UserID
int
YES
不能為空
UserName
varchar
20
NO
不能為空
UserPwd
varchar
20
NO
不能為空
UserLevel
varchar
20
NO
不能為空
表5-10
第六章 界面展示及部分功能模塊主要代碼
6.1 模塊劃分
本系統(tǒng)模塊圖如圖6-1所示。
圖6-1 系統(tǒng)模塊圖
6.2 本程序登錄界面
出于對(duì)系統(tǒng)安全性的考慮,本系統(tǒng)設(shè)置了登錄模塊,只有持有效用戶名和密碼的用戶才能登錄該系統(tǒng)。此外,本系統(tǒng)設(shè)置了訪問權(quán)限,不同訪問權(quán)限的用戶進(jìn)入系統(tǒng)后能完成不同的操作,普通用戶只具有查詢的權(quán)限,管理員用戶可對(duì)普通用戶的信息進(jìn)行更改和入出庫(kù)等所有操作。具體的登錄頁(yè)面如圖6-2所示。
圖6-2系統(tǒng)登錄界面
主要實(shí)現(xiàn)代碼如下:
private void frmLogin_Load(object sender, EventArgs e)
{
dataoperate.ComboxDataBind("SELECT * FROM tb_UserInfo", "UserInfo", "UserName", cboxUserName);
}
private void cboxUserName_SelectedIndexChanged(object sender, EventArgs e)
{
try
{
string strCMD = "SELECT UserLevel FROM tb_UserInfo WHERE UserName=" + cboxUserName.Text + "";
SqlDataReader dr = dbcontrol.SqlExecuteReader(strCMD);
if (dr.Read())
{
strUserLevel = dr["UserLevel"].ToString();
lblUserLevel.Text = strUserLevel;
}
dr.Close();
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
}
private void btnLogin_Click(object sender, EventArgs e)
{
int iResult = dataoperate.Login(cboxUserName.Text.Trim(), txtPwd.Text.Trim());
if (iResult == 0)
{
MessageBox.Show("用戶名或密碼錯(cuò)誤!", "提示!", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
if (iResult == 1)
{
strUserName = cboxUserName.Text.Trim();
strUserPwd = txtPwd.Text.Trim();
frmMain frm = new frmMain();
frm.Show();
this.Hide();
}
}
6.3 本程序運(yùn)行后的效果
當(dāng)使用正確的用戶名和密碼登陸系統(tǒng)以后就進(jìn)入系統(tǒng)的主界面,在系統(tǒng)的主界面中可以選擇你要進(jìn)入的系統(tǒng)模塊,在系統(tǒng)的下面顯示了你登陸的用戶名,用戶權(quán)限以及登錄時(shí)間等。系統(tǒng)主界面如圖6-3所示。
圖6-3 系統(tǒng)主界面
6.4 選擇主窗體
選擇主窗體上的[貨物管理]或貨物管理頁(yè)面上的按鈕可以進(jìn)入入庫(kù)管理、出庫(kù)管理、借貨還貨和盤點(diǎn)管理功能窗體,如圖6-4所示。
圖6-4 貨物管理菜單界面
6.4.1 入庫(kù)管理窗體
入庫(kù)管理窗體中設(shè)置了入庫(kù)管理的基本信息,如圖6-5所示。
圖6-6 貨物入庫(kù)管理窗體
主要實(shí)現(xiàn)代碼如下:
private void frmGoodsIn_Load(object sender, EventArgs e)
{
ds = dbcontrol.GetDataSet("SELECT * FROM tb_GoodsIn", "GoodsIn");
if (ds.Tables[0].Rows.Count == 0)
{
btnDelete.Enabled = false;
}
else
{
btnDelete.Enabled = true;
dgvGoodsIn.DataSource = ds.Tables[0];
}
dataoperate.ComboxDataBind("SELECT ProviderName FROM tb_ProviderInfo",
"ProviderName", "ProviderName", cboxProvider);
dataoperate.ComboxDataBind("SELECT StorehouseName FROM tb_StorehouseInfo",
"StorehouseName", "StorehouseName", cboxStorehouse);
}
private void btnGoodsIn_Click(object sender, EventArgs e)
{
if (txtGoodsName.Text.Trim() == "")
{
MessageBox.Show("貨物名稱不能為空!", "提示!", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
else if (txtGoodsNum.Text.Trim() == "")
{
MessageBox.Show("貨物數(shù)量不能為空!", "提示!", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
else if (txtGoodsPriceIn.Text.Trim() == "")
{
MessageBox.Show("貨物進(jìn)價(jià)不能為空不能為空!", "提示!", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
else
{
try
{
dataoperate.GoodsIn(txtGoodsName.Text.Trim(),
cboxProvider.Text.Trim(), cboxStorehouse.Text.Trim(),
cboxGoodsUnit.Text.Trim(),
txtGoodsNum.Text.Trim(),
txtGoodsPriceIn.Text.Trim(),
DateTime.Now, txtGoodsAdder.Text.Trim(),
txtGoodsInfo.Text);
MessageBox.Show("入庫(kù)成功!", "提示!", MessageBoxButtons.OK, MessageBoxIcon.Information);
frmGoodsIn_Load(sender, e);
Clear();
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
}
}
6.4.2 出庫(kù)管理窗體
出庫(kù)管理窗體中設(shè)置了出庫(kù)管理的基本信息,如圖6-7所示。
圖6-8 貨物出庫(kù)管理窗體
主要實(shí)現(xiàn)代碼如下:
private void frmGoodsOut_Load(object sender, EventArgs e)
{
ds = dbcontrol.GetDataSet("SELECT * FROM tb_GoodsOut", "GoodsOut");
if (ds.Tables[0].Rows.Count == 0)
{
btnDelete.Enabled = false;
}
else
{
btnDelete.Enabled = true;
}
dgvGoodsOut.DataSource = ds.Tables[0];
dataoperate.ComboxDataBind("SELECT DISTINCT GoodsStorehouse FROM tb_GoodsInfo",
"Storehouse", "GoodsStorehouse", cboxStorehouse);
}
private void cboxStorehouse_SelectedIndexChanged(object sender, EventArgs e)
{
dataoperate.ComboxDataBind("SELECT DISTINCT GoodsProvider FROM tb_GoodsInfo WHERE GoodsStorehouse=" + cboxStorehouse.Text + "",
"ProviderInfo", "GoodsProvider", cboxProvider);
cboxGoodsName.Text = "";
}
private void cboxProvider_SelectedIndexChanged(object sender, EventArgs e)
{
dataoperate.ComboxDataBind("SELECT GoodsName FROM tb_GoodsInfo WHERE GoodsStorehouse=" + cboxStorehouse.Text + " AND GoodsProvider=" + cboxProvider.Text + "",
"GoodsName", "GoodsName", cboxGoodsName);
}
private void cboxGoodsName_SelectedIndexChanged(object sender, EventArgs e)
{
SqlDataReader dr = dbcontrol.SqlExecuteReader("SELECT * FROM tb_GoodsInfo WHERE GoodsStorehouse=" + cboxStorehouse.Text + " AND GoodsProvider=" + cboxProvider.Text + " AND GoodsName=" + cboxGoodsName.Text + "");
if (dr.Read())
{
cboxGoodsUnit.Text = dr["GoodsUnit"].ToString();
txtNumNow.Text = dr["GoodsNum"].ToString();
txtPriceOut.Text = dr["GoodsPriceOut"].ToString();
}
dr.Close();
}
6.4.3 借貨管理窗體
借貨管理窗體中設(shè)置了借貨管理的基本信息,如圖6-9所
圖6-9 借貨管理窗體
主要實(shí)現(xiàn)代碼如下:
private void btnBorrow_Click(object sender, EventArgs e)
{
if (txtBorrowNum.Text.Trim() == "")
{
MessageBox.Show("數(shù)量不能為空!", "提示!", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
else if (errorNum.GetError(txtBorrowNum).Equals("數(shù)量格式不正確!"))
{
MessageBox.Show("格式有誤!", "提示!", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
else
{
try
{
int iResult = da
展開閱讀全文