基于java的網(wǎng)上購書系統(tǒng)畢業(yè)設(shè)計(jì)_第1頁
已閱讀1頁,還剩46頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、<p><b>  摘 要</b></p><p>  伴隨著Internet的蓬勃發(fā)展,網(wǎng)絡(luò)購物中心作為電子商務(wù)的一種形式正以其高效、低成本的優(yōu)勢,逐步成為新興的經(jīng)營模式和理念,人們已經(jīng)不再滿足用途信息的瀏覽和發(fā)布,而是渴望著能夠充分享受網(wǎng)絡(luò)所帶來的更加多的便利。網(wǎng)絡(luò)購物正適應(yīng)了當(dāng)今社會(huì)快節(jié)奏地生活,使顧客足不出戶便可以方便快捷輕松地選購自己喜歡的商品。</p>

2、<p>  本系統(tǒng)便是嘗試用JSP在網(wǎng)絡(luò)上架構(gòu)一個(gè)動(dòng)態(tài)的電子商務(wù)網(wǎng)站,它是在Windows XP下,以Mysql為數(shù)據(jù)庫開發(fā)平臺(tái),Tomcat網(wǎng)絡(luò)信息服務(wù)作為應(yīng)用服務(wù)器,采用JSP(Java Server Pages)技術(shù)開發(fā)的網(wǎng)上購物系統(tǒng)。他分前臺(tái)部分和后臺(tái)部分,前臺(tái)部分由用戶使用,主要包括用戶注冊,購物車管理,訂單管理,個(gè)人資料管理,留言板管理等功能;后臺(tái)部分由管理員使用,主要包括商品管理,處理訂單,用戶信息管理,鏈接信息

3、管理等功能。</p><p>  建立后的網(wǎng)站系統(tǒng)是一個(gè)動(dòng)態(tài)、交互式、具有商品提供、系統(tǒng)管理、用戶購買等功能的電子商務(wù)網(wǎng)站。</p><p>  關(guān)鍵詞:JSP;Mysql;Tomcat;Struts;網(wǎng)上購物系統(tǒng)</p><p><b>  目 錄</b></p><p><b>  引 言4<

4、/b></p><p>  第一章 網(wǎng)上購書系統(tǒng)概述5</p><p>  1.1 系統(tǒng)開發(fā)背景5</p><p>  1.1.1網(wǎng)上購書的發(fā)展5</p><p>  1.1.2網(wǎng)上購書系統(tǒng)的現(xiàn)狀5</p><p>  1.2系統(tǒng)實(shí)現(xiàn)的目標(biāo)6</p><p>  1.3系統(tǒng)的開發(fā)

5、意義6</p><p>  第二章 應(yīng)用技術(shù)基礎(chǔ)理論7</p><p>  2.1 JAVA語言基礎(chǔ)知識(shí)7</p><p>  2.1.1 JAVA語言簡介7</p><p>  2.1.2 JAVA語言特點(diǎn)7</p><p>  2.2 JSP的技術(shù)原理8</p><p>  2.

6、2.1 JSP語言8</p><p>  2.2.2 JSP語言特點(diǎn)8</p><p>  2.3 Java Servlets概述9</p><p>  2.3.1 Servlet 技術(shù)9</p><p>  2.3.2 Servlet的結(jié)構(gòu)10</p><p>  2.3.3 Servlet的接口10&l

7、t;/p><p>  2.4 JavaBean簡介11</p><p>  2.5 Struts概述11</p><p>  2.5.1 Struts介紹11</p><p>  2.5.2 MVC簡介12</p><p>  2.5.3 Struts優(yōu)缺點(diǎn)13</p><p>  2.6

8、 mysql概述13</p><p>  2.6.1 mysql介紹13</p><p>  2.6.2 mysql的基本命令14</p><p>  第三章 系統(tǒng)環(huán)境配置15</p><p>  3.1服務(wù)器配置15</p><p>  3.2 Tomcat安裝及配置16</p><p

9、>  3.3 Mysql安裝及配置16</p><p>  第四章 系統(tǒng)需求分析及總體設(shè)計(jì)18</p><p>  4.1 系統(tǒng)需求分析18</p><p>  4.2 總體設(shè)計(jì)19</p><p>  4.3各模塊具體功能說明19</p><p>  4.3.1 注冊功能19</p>

10、<p>  4.3.2 登錄功能19</p><p>  4.3.3 用戶相關(guān)信息維護(hù)功能20</p><p>  4.3.4 商品瀏覽20</p><p>  4.3.5商品交易功能20</p><p>  第五章 數(shù)據(jù)庫設(shè)計(jì)21</p><p>  5.1 數(shù)據(jù)庫E-R圖21</p>

11、;<p>  5.2數(shù)據(jù)實(shí)體類結(jié)構(gòu)概要設(shè)計(jì)22</p><p>  5.2.1 數(shù)據(jù)庫結(jié)構(gòu)設(shè)計(jì)UserInfo22</p><p>  5.2.2 數(shù)據(jù)庫結(jié)構(gòu)設(shè)計(jì)Produts23</p><p>  5.2.3 數(shù)據(jù)庫結(jié)構(gòu)設(shè)計(jì)ProductType23</p><p>  5.2.4 數(shù)據(jù)庫結(jié)構(gòu)設(shè)計(jì)Transactio

12、ns23</p><p>  5.3數(shù)據(jù)庫的初始化及創(chuàng)建24</p><p>  5.3.1數(shù)據(jù)庫的初始化24</p><p>  5.3.2 數(shù)據(jù)庫的創(chuàng)建26</p><p>  第六章 系統(tǒng)詳細(xì)設(shè)計(jì)28</p><p>  6.1系統(tǒng)整體結(jié)構(gòu)28</p><p>  6.2用戶信

13、息自維護(hù)用例圖28</p><p>  6.3系統(tǒng)模塊詳細(xì)設(shè)計(jì)29</p><p>  6.3.1用戶注冊模塊29</p><p>  6.3.2用戶登錄模塊30</p><p>  6.3.3圖書瀏覽模塊31</p><p>  6.3.4書籍選購及交易模塊32</p><p> 

14、 6.3.5用戶定單查詢?yōu)g覽事件模塊34</p><p>  6.3.6用戶信息修改模塊36</p><p>  6.3.7管理員操作界面37</p><p>  6.4購物車類圖結(jié)構(gòu)39</p><p>  第七章 系統(tǒng)測試及發(fā)布及難點(diǎn)分析40</p><p>  7.1本系統(tǒng)使用的運(yùn)行及開發(fā)平臺(tái)40&l

15、t;/p><p>  7.2系統(tǒng)測試40</p><p>  7.2.1 系統(tǒng)關(guān)鍵部分測試分析40</p><p>  7.2.2 單元測試分析40</p><p>  7.2.3 測試分析總結(jié)及說明41</p><p>  7.2.4 系統(tǒng)的性能分析42</p><p><b>

16、;  總 結(jié)43</b></p><p><b>  致 謝44</b></p><p>  參 考 文 獻(xiàn)45</p><p><b>  引 言</b></p><p>  目前,網(wǎng)絡(luò)正以一種前所未有的沖擊力在影響著人類的活動(dòng),包括人類的生產(chǎn)和日常生活。網(wǎng)絡(luò)的誕生和發(fā)展

17、,顛覆了傳統(tǒng)的信息傳播方式,沖破了存在于傳統(tǒng)交流方式中時(shí)間和空間的種種壁壘,極大地改變了人類從物質(zhì)到精神、從形式到內(nèi)容、從生產(chǎn)到生活的各種活動(dòng),并且給人類帶來了新的機(jī)遇和挑戰(zhàn)。</p><p>  在互聯(lián)網(wǎng)服務(wù)業(yè)務(wù)方面:電子郵件、搜索引擎、網(wǎng)上銀行、在線交易、網(wǎng)絡(luò)廣告、網(wǎng)絡(luò)新聞、網(wǎng)絡(luò)游戲等服務(wù)業(yè)務(wù)仍然快速的發(fā)展著。</p><p>  21世紀(jì)是網(wǎng)絡(luò)飛速發(fā)展的時(shí)代,上網(wǎng)、創(chuàng)建網(wǎng)站已經(jīng)成為熱

18、門話題。Internet技術(shù)得到持續(xù)、猛烈的發(fā)展,已經(jīng)成為計(jì)算機(jī)產(chǎn)業(yè)的一個(gè)技術(shù)熱點(diǎn),越來越多的企業(yè)開始關(guān)注網(wǎng)絡(luò),許多人正在或正準(zhǔn)備學(xué)習(xí)網(wǎng)絡(luò)知識(shí),進(jìn)行網(wǎng)絡(luò)開發(fā)或創(chuàng)建自己的網(wǎng)站。</p><p>  本次畢業(yè)設(shè)計(jì)——基于J2EE的網(wǎng)上購書網(wǎng)站的設(shè)計(jì),是在Windows XP下,以Msql為數(shù)據(jù)庫開發(fā)平臺(tái),Tomcat網(wǎng)絡(luò)信息服務(wù)作為應(yīng)用服務(wù)器,采用JSP(Java Server Pages)技術(shù)開發(fā)的。</p&

19、gt;<p>  在本論文中全面詳細(xì)地介紹了網(wǎng)上購書系統(tǒng)的設(shè)計(jì)方案,第1章為網(wǎng)上購書系統(tǒng)概述,包括系統(tǒng)的開發(fā)背景,網(wǎng)上購物的發(fā)展,網(wǎng)上購書系統(tǒng)的現(xiàn)狀,系統(tǒng)實(shí)現(xiàn)的目標(biāo),系統(tǒng)開發(fā)的意義。第2章為JAVA的基礎(chǔ)理論,包括JSP的技術(shù)原理,Java及Java Servlets概述,JavaBean簡介,在JSP中使用XML,mysql概述,Struts概述等。第3章為系統(tǒng)構(gòu)架,包括服務(wù)器配置,JAVA虛擬機(jī)的安裝配置,Tomcat

20、環(huán)境搭建,mysql的安裝配置等;第4章為系統(tǒng)需求分析及總體設(shè)計(jì),包括需求分析,系統(tǒng)功能模塊設(shè)計(jì),對(duì)具體功能及用例說明,數(shù)據(jù)庫需求分析;第5章為數(shù)據(jù)庫設(shè)計(jì),包括數(shù)據(jù)庫結(jié)構(gòu)設(shè)計(jì),用JSP連接數(shù)據(jù)庫;第6章系統(tǒng)詳細(xì)設(shè)計(jì),包括前臺(tái)和后臺(tái)兩個(gè)大的部分,前臺(tái)部分由用戶使用,主要包括用戶注冊,購物車管理,訂單管理,個(gè)人資料管理;后臺(tái)部分由管理員使用,主要包括會(huì)員信息管理,主要包括商品管理,處理訂單,用戶信息管理,鏈接信息管理等功能;第7章為系統(tǒng)測試

21、及發(fā)布及難點(diǎn)分析,包括開發(fā)難點(diǎn)和技巧,系統(tǒng)的測試;系統(tǒng)中存在的問題及解決方法;第8章為總結(jié);第9章為致謝;第10章為參考文獻(xiàn)。</p><p>  第一章 網(wǎng)上購書系統(tǒng)概述</p><p>  1.1 系統(tǒng)開發(fā)背景</p><p>  1.1.1網(wǎng)上購書的發(fā)展</p><p>  近年來,隨著Internet的迅速崛起,互聯(lián)網(wǎng)已日益成為收集提

22、供信息的最佳渠道并逐步進(jìn)入傳統(tǒng)的流通領(lǐng)域。于是電子商務(wù)開始流行起來,越來越多的商家在網(wǎng)上建起在線商店,向消費(fèi)者展示出一種新穎的購物理念。</p><p>  網(wǎng)上購書系統(tǒng)作為B2B,B2C(Business to Customer,即企業(yè)對(duì)消費(fèi)者),C2C(Customer to Customer,即消費(fèi)者對(duì)消費(fèi)者)電子商務(wù)的前端商務(wù)平臺(tái),在其商務(wù)活動(dòng)全過程中起著舉足輕重的作用。本文主要考慮的是如何建設(shè)B

23、2C的網(wǎng)上購物系統(tǒng)。</p><p>  網(wǎng)上購書是一種具有交互功能的商業(yè)信息系統(tǒng)。它向用戶提供靜態(tài)和動(dòng)態(tài)兩類信息資源。所謂靜態(tài)信息是指那些比經(jīng)常變動(dòng)或更新的資源,如公司簡介、管理規(guī)范和公司制度等等;動(dòng)態(tài)信息是指隨時(shí)變化的信息,如商品報(bào)價(jià),會(huì)議安排和培訓(xùn)信息等。網(wǎng)上購書系統(tǒng)具有強(qiáng)大的交互功能,可使商家和用戶方便的傳遞信息,完成電子貿(mào)易或EDI交易。這種全新的交易方式實(shí)現(xiàn)了公司間文檔與資金的無紙化交換。</p

24、><p>  1.1.2網(wǎng)上購書系統(tǒng)的現(xiàn)狀</p><p>  目前在國內(nèi)PHP與ASP應(yīng)用最為廣泛。而JSP由于是一種較新的技術(shù),國內(nèi)采用的較少。但在國外,JSP已經(jīng)是比較流行的一種技術(shù),尤其是電子商務(wù)類的網(wǎng)站,多采用JSP。</p><p>  首先,PHP缺乏規(guī)模支持。其次,缺乏多層結(jié)構(gòu)支持。對(duì)于大負(fù)荷站點(diǎn),解決方法只有一個(gè):分布計(jì)算。數(shù)據(jù)庫、應(yīng)用邏輯層、表示邏輯

25、層彼此分開,而且同層也可以根據(jù)流量分開,組成二維陣列。而PHP則缺乏這種支持。還有上面提到過的一點(diǎn),PHP提供的數(shù)據(jù)庫接口支持不統(tǒng)一,這就使得它不適合運(yùn)用在電子商務(wù)中。</p><p>  ASP和JSP則沒有以上缺陷,ASP可以通過Microsoft Windowsd的COM/DCOM獲得ActiveX規(guī)模支持,通過DCOM和Transcation Server獲得結(jié)構(gòu)支持;JSP可以通過SUN Java的Ja

26、va Class和EJB獲得規(guī)模支持,通過EJB/CORBA以及眾多廠商的Application Server獲得結(jié)構(gòu)支持。</p><p>  三者中,JSP應(yīng)該是未來發(fā)展的趨勢。世界上一些大的電子商務(wù)解決方案提供商都采用JSP/Servlet。</p><p>  總的來說,ASP,PHP,JSP三者都有相當(dāng)數(shù)量的支持者,而這三者也各有所長,在開發(fā)過程中,我們應(yīng)該根據(jù)實(shí)際的需要來使用最

27、合適的技術(shù),本系統(tǒng)則采用較新的jsp技術(shù),一方面jsp的安全性和跨平臺(tái)性比較好,另一方面,我也希望能從開發(fā)該系統(tǒng)的過程中,深入學(xué)習(xí)一下這門編程語言。</p><p>  1.2系統(tǒng)實(shí)現(xiàn)的目標(biāo)</p><p>  現(xiàn)在流行的網(wǎng)上購物系統(tǒng)不僅要有漂亮的網(wǎng)頁,更要有嚴(yán)謹(jǐn)?shù)囊?guī)劃,注重每一個(gè)細(xì)小的環(huán)節(jié)。這樣才能使得在電子交易時(shí)避免不必要錯(cuò)誤發(fā)生。我們將使用HTML、JSP等技術(shù)來編輯網(wǎng)頁,并運(yùn)用JD

28、BC技術(shù)把數(shù)據(jù)庫和動(dòng)態(tài)網(wǎng)頁相關(guān)聯(lián)。傳統(tǒng)的管理信息系統(tǒng)信息獲取方法是由專業(yè)文字錄入人員將信息輸入到管理系統(tǒng)的數(shù)據(jù)庫中,這種方法在數(shù)據(jù)量不大時(shí)有很多的應(yīng)用場合。當(dāng)數(shù)據(jù)量比較大,并且有較強(qiáng)的專業(yè)性時(shí),錄入的費(fèi)用和出錯(cuò)的可能性都相應(yīng)上升。本設(shè)計(jì)在實(shí)際應(yīng)用中的解決方案是建立網(wǎng)站, 以及自己的數(shù)據(jù)庫,使得所需商品信息可以及時(shí)的保存、更新,可以更好的及時(shí)了解商品買賣的情況。</p><p>  1.3系統(tǒng)的開發(fā)意義</

29、p><p>  Internet的發(fā)展,為改變傳統(tǒng)的商業(yè)運(yùn)作模式提供了一種技術(shù)上的可行性的方案:利用Internet的技術(shù)和協(xié)議,建立各種企業(yè)內(nèi)部網(wǎng)Intranet,企業(yè)外部網(wǎng)Extranet,通過廉價(jià)的通訊手段,將買家與賣家、廠商和合作伙伴緊密結(jié)合在了一起,消除時(shí)間與空間帶來的障礙,從而大大的節(jié)約了交易成本,擴(kuò)大了交易范圍。</p><p>  當(dāng)今比較流行的網(wǎng)上購物系統(tǒng)國外有“淘寶(www

30、.taobao.com)”,國內(nèi)有“當(dāng)當(dāng)(www.dangdang.com)”。它們都是相當(dāng)優(yōu)秀的電子商務(wù)網(wǎng)站,對(duì)其他的網(wǎng)站提供了良好的典范。設(shè)計(jì)中可以學(xué)習(xí)參考他們的思想,了解和熟悉整個(gè)網(wǎng)站的開發(fā)流程及完整的電子商務(wù)網(wǎng)站應(yīng)有的功能和注意事項(xiàng)。</p><p>  第二章 應(yīng)用技術(shù)基礎(chǔ)理論</p><p>  2.1 JAVA語言基礎(chǔ)知識(shí)</p><p>  2.1.

31、1 JAVA語言簡介</p><p>  Java來自于Sun公司的一個(gè)叫Green的項(xiàng)目,其原先的目的是為家用消費(fèi)電子產(chǎn)品開發(fā)一個(gè)分布式代碼系統(tǒng),這樣我們可以把E-mail發(fā)給電冰箱、電視機(jī)等家用電器,對(duì)它們進(jìn)行控制,和它們進(jìn)行信息交流。開始,準(zhǔn)備采用C++,但C++太復(fù)雜,安全性差,最后基于C++開發(fā)了一種新的語言O(shè)ak(Java的前身),Oak是一種用于網(wǎng)絡(luò)的精巧而安全的語言,Sun公司曾以此投標(biāo)一個(gè)交互式

32、電視項(xiàng)目,但結(jié)果被SGI打敗??蓱z的Oak幾乎無家可歸,恰巧這時(shí)Mark Ardreesen開發(fā)的Mosaic和Netscape啟發(fā)了Oak項(xiàng)目組成員,他們用Java編 制 了HotJava瀏 覽器,得到了Sun公司首席執(zhí)行官Scott McNealy的支持,觸發(fā)了Java進(jìn) 軍Internet。 Java的取名也有一則趣聞,有一天,幾 位Java成員組的會(huì)員正在討論給這個(gè)新的語言取什么名字,當(dāng)時(shí)他們正在咖啡館喝著Java(爪哇)咖 啡

33、,有一個(gè)人靈機(jī)一動(dòng)說就叫Java怎 樣,得到了其他人的贊賞,于是,Java這個(gè)名字就這樣傳開了。</p><p>  2.1.2 JAVA語言特點(diǎn)</p><p><b>  ◆簡單的</b></p><p>  Java最初是為對(duì)家用電器進(jìn)行集成控制而設(shè)計(jì)的一種語言,因此它必須簡單明了。</p><p><b&g

34、t;  ◆面向?qū)ο蟮?</b></p><p>  面向?qū)ο罂梢哉f是Java最重要的特性,它支持繼承、重載、多態(tài)等面向?qū)ο蟮奶匦浴?lt;/p><p><b>  ◆健壯的</b></p><p>  Java致力于檢查程序在編譯和運(yùn)行時(shí)的錯(cuò)誤。</p><p><b>  ◆安全的</b>

35、</p><p>  一方面,在Java語言里,刪除了指針和釋放內(nèi)存等C++功能,避免了非法內(nèi)存操作。另一方面,通過Java的安全體系架構(gòu)來確保Java代碼的安全性。</p><p><b>  ◆解釋的</b></p><p>  Java代碼是解釋執(zhí)行的,我們使用Java編譯器將Java代碼編譯成字節(jié)碼,這是一種中間代碼,然后由Java解釋

36、器解釋執(zhí)行。</p><p><b>  ◆與平臺(tái)無關(guān)的</b></p><p>  只要有Java運(yùn)行系統(tǒng)的機(jī)器都能執(zhí)行這種中間代碼。</p><p><b>  ◆多線程的</b></p><p>  Java語言的一個(gè)重要特性就是在語言級(jí)支持多線程的程序設(shè)計(jì)。</p><p

37、><b>  ◆動(dòng)態(tài)的</b></p><p>  它允許程序動(dòng)態(tài)地裝入運(yùn)行過程中所需要的類。</p><p>  2.2 JSP的技術(shù)原理</p><p>  2.2.1 JSP語言</p><p>  在傳統(tǒng)的網(wǎng)頁HTML文件(*,htm,*,html)中加入Java程序片段(Scriptlet)和JSP標(biāo)記(

38、tag),就構(gòu)成了JSP網(wǎng)頁(*,jsp)。JSP頁面看上去象標(biāo)準(zhǔn)的HTML和XML頁面,并附帶有JSP引擎能夠處理和抽取的額外元件。Web服務(wù)器在遇到訪問JSP網(wǎng)頁的請(qǐng)求時(shí),首先執(zhí)行其中的程序片段,然后將執(zhí)行結(jié)果以HTML格式返回給用戶。程序都在服務(wù)器端執(zhí)行,網(wǎng)絡(luò)上傳送給客戶端的僅是得到的結(jié)果,對(duì)客戶瀏覽器的要求最低。它基于強(qiáng)大的Java語言,具有良好的伸縮性,在網(wǎng)絡(luò)數(shù)據(jù)庫應(yīng)用開發(fā)領(lǐng)域具有得天獨(dú)厚的優(yōu)勢。</p><

39、;p>  2.2.2 JSP語言特點(diǎn)</p><p>  JSP技術(shù)在多個(gè)方面加速了動(dòng)態(tài)Web頁面的開發(fā):</p><p> ?。?)將內(nèi)容的生成和顯示進(jìn)行分離</p><p>  使用JSP技術(shù),Web頁面開發(fā)人員可以使用HTML或者XML標(biāo)識(shí)來設(shè)計(jì)和格式化最終頁面。使用JSP標(biāo)識(shí)或者小腳本來生成頁面上的動(dòng)態(tài)內(nèi)容。生成內(nèi)容的邏輯被封裝在標(biāo)識(shí)和JavaBean

40、s組件中,并且捆綁在小腳本中,所有的腳本在服務(wù)器端運(yùn)行。如果核心邏輯被封裝在標(biāo)識(shí)和Beans中,那么其他人,如Web管理人員和頁面設(shè)計(jì)者,能夠編輯和使用JSP頁面,而不影響內(nèi)容的生成。</p><p> ?。?)強(qiáng)調(diào)可重用的組件</p><p>  絕大多數(shù)JSP頁面依賴于可重用的,跨平臺(tái)的組件(JavaBeans或者Enterprise JavaBeansTM組件)來執(zhí)行應(yīng)用程序所要求的

41、更為復(fù)雜的處理。開發(fā)人員能夠共享和交換執(zhí)行普通操作的組件。</p><p> ?。?)采用標(biāo)識(shí)簡化頁面開發(fā)</p><p>  Web頁面開發(fā)人員不會(huì)都是熟悉腳本語言的編程人員。JavaServer Page技術(shù)封裝了許多功能,這些功能是在易用的、與JSP相關(guān)的XML標(biāo)識(shí)中進(jìn)行動(dòng)態(tài)內(nèi)容生成所需要的。標(biāo)準(zhǔn)的JSP標(biāo)識(shí)能夠訪問和實(shí)例化JavaBeans組件,設(shè)置或者檢索組件屬性,下載Apple

42、t,以及執(zhí)行用其他方法更難于編碼和耗時(shí)的功能。</p><p>  (4)JSP能提供所有Servlets功能</p><p>  與Servlets相比,JSP能提供所有Servlets功能,它比用Println書寫和修改HTML更方便。可以更明確地進(jìn)行分工,Web頁面設(shè)計(jì)人員編寫HTML,只需留出空間讓Servlets程序員插入動(dòng)態(tài)部分即可。</p><p> 

43、?。?)健壯的存儲(chǔ)管理和安全性</p><p>  由于JSP頁面的內(nèi)置腳本語言是基于Java編程語言的,而且所有的JSP頁面都被編譯成為Java Servlet,JSP頁面就具有Java技術(shù)的所有好處,包括健壯的存儲(chǔ)管理和安全性。</p><p> ?。?)一次編寫,各處運(yùn)行</p><p>  作為Java平臺(tái)的一部分,JSP擁有Java編程語言“一次編寫,各處

44、運(yùn)行”的特點(diǎn)。隨著越來越多的供應(yīng)商將JSP支持添加到他們的產(chǎn)品中,您可以使用自己所選擇的服務(wù)器和工具,更改工具或服務(wù)器并不影響當(dāng)前的應(yīng)用。</p><p>  2.3 Java Servlets概述</p><p>  2.3.1 Servlet 技術(shù)</p><p>  Java Servlet是JSP技術(shù)的基礎(chǔ),JSP本身就是預(yù)先被編譯成Servlet,然后再運(yùn)

45、行的,而且大型的Web應(yīng)用程序的開發(fā)需要Java Servlet和JSP配合才能完成,Servlet這個(gè)名稱大概源于Applet,現(xiàn)在國內(nèi)的翻譯方式很多,本文為了避免誤會(huì),本文直接采用Servlet這個(gè)名稱而不做任何翻譯,讀者如果愿意,可以稱之為“小服務(wù)程序”。Servlet其實(shí)和傳統(tǒng)的CGI程序和ISAPI、NSAPI等Web程序開發(fā)工具的作用是相同的,在使用Java Servlet以后,用戶不必再使用效率低下的CGI方式,也不必使用

46、只能在某個(gè)固定Web服務(wù)器平臺(tái)運(yùn)行的API方式來動(dòng)態(tài)生成Web頁面。許多Web服務(wù)器都支持Servlet,即使不直接支持Servlet的Web服務(wù)器也可以通過附加的應(yīng)用服務(wù)器和模塊來支持Servlet。得益于Java的跨平臺(tái)的特性,Servlet也是平臺(tái)無關(guān)的,實(shí)際上,只要符合Java Servlet規(guī)范,Servlet是完全平臺(tái)無關(guān)且是Web服務(wù)器無關(guān)的。</p><p>  2.3.2 Servlet的結(jié)構(gòu)&

47、lt;/p><p>  當(dāng)一個(gè)servlet接收來自客戶端的調(diào)用請(qǐng)求, 它接收兩個(gè)對(duì)象: 一個(gè)是ServletRequest,另外一個(gè)是ServletResponse, 這個(gè)ServletRequest類概括從客戶端到服務(wù)器之間的聯(lián)系, 而 ServletResponse類概括從servlet返回客戶端的聯(lián)系, </p><p>  ServletRequest interface 可以獲取到

48、這樣一些信息如由客戶端傳送的闡述名稱,客戶端正在使用的協(xié)議, 產(chǎn)生請(qǐng)求并且接收請(qǐng)求的服務(wù)器遠(yuǎn)端主機(jī)名, 它也提供獲取數(shù)據(jù)流的servlet, ServletInputStream, 這些數(shù)據(jù)是客戶端引用中使用HTTP POST 和 PUT 方法遞交的, 一個(gè)ServletRequest的子類可以讓 servlet獲取更多的協(xié)議特性數(shù)據(jù), 例如: HttpServletRequest 包含獲取 HTTP-specific頭部信息的方法,

49、</p><p>  ServletResponse interface 給出相應(yīng)客戶端的servlet方法, 它允許servlet 設(shè)置內(nèi)容長度和回應(yīng)的mime類型, 并且提供輸出流, ServletOutputStream, 通過編寫者可以發(fā)回相應(yīng)數(shù)據(jù), ServletResponse子類可以給出更多 protocol-specific容量的信息。</p><p>  2.3.3 Se

50、rvlet的接口</p><p>  Servlet 從javax包的httpservlet類擴(kuò)展,在HttpServlet中加入了一些附加的方法,這些方法可以被協(xié)助處理HTTP 基本請(qǐng)求的HttpServlet類中的方法service自動(dòng)地調(diào)用。這些方法有:</p><p>  ◆doGet 用來處理HTTP的GET請(qǐng)求。</p><p>  ◆doPost 用來

51、處理HTTP的POST請(qǐng)求。</p><p>  ◆doPut用來處理HTTP的PUT請(qǐng)求。</p><p>  ◆doDelete用來處理HTTP的DELETE請(qǐng)求。</p><p>  ◆doHead 用來處理HTTP的HEAD請(qǐng)求。</p><p>  ◆doOptions用來處理HTTP的OPTIONS請(qǐng)求。</p>&

52、lt;p>  ◆doTrace用來處理HTTP的TRACE請(qǐng)求。</p><p>  2.4 JavaBean簡介</p><p>  JavaBean是一種基于Java的軟件組件,JavaBean和Active控件一樣,可以通過封裝業(yè)務(wù)邏輯建立一整套可重復(fù)利用的對(duì)象庫。JSP對(duì)于在Web應(yīng)用中集成JavaBean組件提供了完善的支持,這種支持不僅能縮短開發(fā)時(shí)間(可以直接利用經(jīng)過測試

53、和可信任的已有組件),避免重復(fù)開發(fā),也為JSP應(yīng)用帶來了更多的可伸縮性。JavaBean組件可以用來執(zhí)行復(fù)雜的計(jì)算任務(wù),或負(fù)責(zé)與數(shù)據(jù)庫的交互及數(shù)據(jù)提取等。</p><p>  由于Java語言在這些方面所具有的特點(diǎn)和優(yōu)勢,使得基于它的軟件JavaBean組件技術(shù)倍受人們關(guān)注。它的任務(wù)就是:一次編寫,可以在任何地方執(zhí)行,可以在任何地方重用。JavaBean組件可以在任何地方重用包括了可以在應(yīng)用程序、其他組件、文檔、

54、Web站點(diǎn)和應(yīng)用程序構(gòu)造器工具等多種方案中再利用。</p><p>  2.5 Struts概述</p><p>  2.5.1 Struts介紹</p><p>  Struts是一種開源軟件,它可以幫助開發(fā)人員更快更容易的開發(fā)Web程序。Struts所基于的標(biāo)準(zhǔn)技術(shù)----例如JavaBeans,servlets和 JSP,是大多數(shù)開發(fā)人員非常熟悉掌握的, 在軟

55、件開發(fā)過程中通過使用標(biāo)準(zhǔn)組建, 并用填空式的開發(fā)方法, Struts可以幫助程序員減輕每個(gè)新項(xiàng)目都重復(fù)進(jìn)行那些既費(fèi)時(shí)又繁瑣的工作。</p><p>  Struts使用的是Model2體系結(jié)構(gòu)。ActionServlet負(fù)責(zé)控制總流程。另外一個(gè)Action類負(fù)責(zé)存取業(yè)務(wù)邏輯類。當(dāng)ActionServlet類從容器中獲取一個(gè)請(qǐng)求時(shí),它使用請(qǐng)求的URI(路徑)來決定是哪一個(gè)Action來處理該請(qǐng)求。一個(gè)Action可

56、以檢驗(yàn)輸入的合法性、通過業(yè)務(wù)邏輯層來讀取數(shù)據(jù)庫或者其他數(shù)據(jù)服務(wù)中的信息。要完成這些功能,Action需要用戶提交給它處理數(shù)據(jù)。為了每一個(gè)Action都要處理從請(qǐng)求中提取輸入數(shù)據(jù)的操作,Struts將這些輸入數(shù)據(jù)綁定到JavaBean中。每一個(gè)這樣的輸入Bean都是Struts中ActionForm類的子類。ActionServlet通過查看請(qǐng)求的路徑就可以決定哪一個(gè)ActionForm用來包含輸入數(shù)據(jù)。這些ActionForm類都應(yīng)該是

57、org,apache,struts,action,ActionForm的子類。每一個(gè)HTTP請(qǐng)求都必須有一個(gè)HTTP響應(yīng)。但Struts自己并不生成響應(yīng),而是將該請(qǐng)求轉(zhuǎn)發(fā)到其他的資源上如JSP頁面。Struts提供一個(gè)名為ActionForward的類來將邏輯名保存到每個(gè)頁面的路徑。當(dāng)業(yè)務(wù)邏輯部</p><p>  2.5.2 MVC簡介</p><p><b>  MVC模式:

58、</b></p><p>  我們開始從傳統(tǒng)形式上描述MVC然后討論它如何能適應(yīng)網(wǎng)絡(luò)的應(yīng)用。MVC模式三個(gè)部分中任一個(gè)都是經(jīng)過檢驗(yàn)的,他們分別執(zhí)行相應(yīng)的公共模塊。這個(gè)模式的主要意圖是分成三個(gè)相互獨(dú)立的交互的模塊:模型,視圖和控制器。模型的核心是一個(gè)邏輯函數(shù),視圖是用來顯示用戶應(yīng)用程序傳遞的數(shù)據(jù),而控制器是控制用戶的交互和輸入的。 三者的通信是通過一個(gè)變換裝置保持協(xié)調(diào)同步的</p><

59、;p>  模型-視圖-控制器(MVC)(如圖2.1):</p><p>  1、模型(Model)</p><p>  模型是應(yīng)用程序的主體部分。模型表示業(yè)務(wù)數(shù)據(jù),或者業(yè)務(wù)邏輯,</p><p>  2、視圖(View)</p><p>  視圖是應(yīng)用程序中用戶界面相關(guān)的部分,是用戶看到并與之交互的界面。 </p><

60、;p>  3、控制器(controller) </p><p>  控制器工作就是根據(jù)用戶的輸入,控制用戶界面數(shù)據(jù)顯示和更新model對(duì)象狀態(tài)。</p><p>  圖 2.1 MVC組件類型的關(guān)系和功能</p><p>  MVC式的出現(xiàn)不僅實(shí)現(xiàn)了功能模塊和顯示模塊的分離,同時(shí)它還提高了應(yīng)用系統(tǒng)的可維護(hù)性、可擴(kuò)展性、可移植性和組件的可復(fù)用性</p>

61、;<p>  2.5.3 Struts優(yōu)缺點(diǎn)</p><p><b>  優(yōu)點(diǎn):</b></p><p>  ◆有利于構(gòu)筑穩(wěn)健的應(yīng)用</p><p>  ◆減少了代碼的重復(fù),易于維護(hù) </p><p>  ◆有利于軟件工程化管理</p><p><b>  缺點(diǎn):</

62、b></p><p>  ◆增加了系統(tǒng)結(jié)構(gòu)和實(shí)現(xiàn)的復(fù)雜性</p><p>  ◆視圖與控制器間的過于緊密的連接</p><p>  ◆視圖對(duì)模型數(shù)據(jù)的低效率訪問</p><p>  2.6 mysql概述</p><p>  2.6.1 mysql介紹</p><p>  MySQL是一個(gè)

63、小型關(guān)系型數(shù)據(jù)庫管理系統(tǒng),開發(fā)者為瑞典MySQL AB公司。在2008年1月16號(hào)被Sun公司收購。目前MySQL被廣泛地應(yīng)用在Internet上的中小型網(wǎng)站中。由于其體積小、速度快、總體擁有成本低,尤其是開放源碼這一特點(diǎn),許多中小型網(wǎng)站為了降低網(wǎng)站總體擁有成本而選擇了MySQL作為網(wǎng)站數(shù)據(jù)庫。</p><p>  2.6.2 mysql的基本命令</p><p><b>  -

64、---創(chuàng)建數(shù)據(jù)庫</b></p><p>  mysql> create database 數(shù)據(jù)庫名稱</p><p><b>  ----創(chuàng)建表</b></p><p>  mysql> create table 表名 (列的名字(id)類型(int(4))primary key(定義主鍵) auto_incremen

65、t(描述 自增),……,);</p><p>  ----查看所有數(shù)據(jù)庫</p><p>  mysql> show databases 數(shù)據(jù)庫名稱;</p><p>  ----使用某個(gè)數(shù)據(jù)庫</p><p>  mysql> use database 數(shù)據(jù)庫名稱;</p><p>  ----查看所使用

66、數(shù)據(jù)庫下所有的表</p><p>  mysql> show tables;</p><p>  ----顯示表的屬性結(jié)構(gòu)</p><p>  mysql> desc 表名;</p><p>  ----選擇表中數(shù)據(jù)的顯示</p><p>  * 代表選擇所有列 ,</p><p>

67、  mysql> select * from 表名 where id=?[and name=?] [or name=?];</p><p>  mysql> select id,name from 表名order by 某一列的名稱 desc(降序,asc為升序)</p><p>  ----刪除表中的數(shù)據(jù)</p><p>  mysql> del

68、ete from table where id=?[or name=? (and name=?)];</p><p><b>  ----刪除表</b></p><p>  mysql> drop table;</p><p><b>  ----刪除數(shù)據(jù)庫</b></p><p>  mys

69、ql> drop database;</p><p>  第三章 系統(tǒng)環(huán)境配置</p><p><b>  3.1服務(wù)器配置</b></p><p>  第一步:從官方網(wǎng)站http://java.sun.com下載該軟件的最新版本。我所下載的是jdk-6u13-windows-i586-p.exe文件。</p><p&

70、gt;  第二步:雙擊.exe文件,安裝在C:\Program Files\Java\jdk1.6.0_13。</p><p>  第三步:JDK的環(huán)境配置:在Windows中用鼠標(biāo)指向我的電腦,按右鍵,選擇“屬性”,在“系統(tǒng)特性”表單內(nèi)選擇“高級(jí)”標(biāo)簽,在“高級(jí)”標(biāo)簽內(nèi)選擇“環(huán)境變量”,在系統(tǒng)變量中加入變量JAVA_HOME(變量名為C:\Program Files\Java\jdk1.6.0_13.class

71、path(變量值為C:\Program Files\Java\ jdk1.6.0_13\lib\dt.jar;C:\ProgramFiles\Java\jdk1.5.0_06\lib\tools,jar;C:\ProgramFiles\Java\jdk1.5.0_06)和path(變量值為C:\Program Files\Java\jdk1.6.0_13\bin)。</p><p>  安裝和配置完畢后,在“命令

72、提示符”中輸入javac,會(huì)出現(xiàn)如圖3.1所示,則說明JDK安裝和配置都是正確的。</p><p>  圖3.1 javac調(diào)試界面</p><p>  3.2 Tomcat安裝及配置</p><p>  直接運(yùn)行下載的apache-tomcat-5.5.26.exe文件,按照一般的Windows程序安裝步驟即可安裝好Tomcat,安裝時(shí)它會(huì)自動(dòng)尋找JDK的位置。

73、安裝過程中需要選擇一個(gè)文件夾作為Tomcat的安裝目錄。我選擇安裝的位置是C:\Tomca 5.5。</p><p>  安裝完成以后,添加一個(gè)Tomcat的環(huán)境變量,添加方法和JDK的環(huán)境變量的添加方法相同,設(shè)置變量名為TOMCAT_HOME,變量值為C:\Tomcat 5.5。</p><p>  設(shè)置完畢后就可以運(yùn)行Tomcat服務(wù)器了。Tomcat成功啟動(dòng)后,在瀏覽器中輸入http

74、://localhost:8080/,如果出現(xiàn)歡迎界面,則說明Tomcat安裝成功。歡迎界面如圖3.2所示。</p><p>  圖3.2 Tomcat歡迎界面</p><p>  3.3 Mysql安裝及配置</p><p>  Mysql的安裝文件可以直接到 http://www.mysql.com 下載,獲得for win32的,zip包,建議選擇4.0.2

75、0d版本。下載獲得Mysql的for win32安裝包后,用winzip解壓縮,直接運(yùn)行setup,exe,需要注意的是選擇一個(gè)安裝路徑,當(dāng)然,安裝路徑可以任意,建議選擇C:\MySQL目錄。安裝完成后MySQL也就完成了。默認(rèn)的用戶名是root,密碼為123456。</p><p>  Mysql安裝完成后,請(qǐng)通過開始-程序-附件-命令提示符進(jìn)入:</p><p>  錄入cd C:\m

76、ysql\bin 并按下回車鍵,將目錄切換為 cd C:\mysql\bin</p><p>  在 C:\mysql\bin> 命令提示符下錄入 mysqld-nt -install 命令,然后按下回車,如果出現(xiàn) Service successfully installed 的提示, 這表示你已成功的將 MySQL 安裝成一項(xiàng) Windows 的服務(wù)。</p><p>  點(diǎn)擊 開

77、始-程序-管理工具-服務(wù) ,你可以看到Mysql已經(jīng)成為眾多服務(wù)項(xiàng)目中的一項(xiàng),不過此時(shí)它還未被啟動(dòng), 因此接下來我們就啟動(dòng)它。</p><p>  啟動(dòng) MySQL 服務(wù)的方法有以下三種,請(qǐng)自行選擇其中一種來進(jìn)行:</p><p>  重啟機(jī)器時(shí)自動(dòng)啟動(dòng)它</p><p>  在服務(wù)窗口中選取 MySQL 服務(wù)名稱,然后按下啟動(dòng)按鈕來啟動(dòng)它</p>&

78、lt;p>  在“命令提示字符”窗口中輸入 NET START MySQL 指令來啟動(dòng)它</p><p>  Mysql數(shù)據(jù)安裝完成,系統(tǒng)會(huì)默認(rèn)生成一個(gè)名為test的數(shù)據(jù)庫。一般情況下,由于該數(shù)據(jù)需要用root用戶進(jìn)行訪問,從安全性角度而言,我們建議你新建一個(gè)數(shù)據(jù)庫,并給這個(gè)數(shù)據(jù)庫分配一個(gè)新的用戶來訪問。(如下圖3.3為數(shù)據(jù)庫運(yùn)行界面)</p><p>  圖3.3數(shù)據(jù)庫運(yùn)行界面&l

79、t;/p><p>  第四章 系統(tǒng)需求分析及總體設(shè)計(jì)</p><p>  4.1 系統(tǒng)需求分析</p><p>  此基于J2EE的網(wǎng)上書店系統(tǒng)主要是實(shí)現(xiàn)網(wǎng)上選書、購書、產(chǎn)生訂單等功能的系統(tǒng)。一個(gè)典型的網(wǎng)上商城一般都需要實(shí)現(xiàn)商品信息的動(dòng)態(tài)提示、購物車管理、客戶信息注冊登錄管理、訂單處理等模塊。</p><p>  根據(jù)網(wǎng)上書店的基本需求,本系統(tǒng)需

80、要完成的具體任務(wù)如下:</p><p>  會(huì)員注冊:為了能夠?qū)崿F(xiàn)圖書商品的購買,需要管理客戶相關(guān)的聯(lián)系方式、送貨地點(diǎn)等相關(guān)的信息。</p><p>  書圖查詢:當(dāng)客戶進(jìn)入網(wǎng)上書店時(shí),應(yīng)該在主頁面中顯示書目信息,以供客戶選擇所需圖書,同時(shí)用戶可以進(jìn)一步對(duì)書籍內(nèi)容進(jìn)行查看預(yù)覽等。</p><p>  購物車管理:當(dāng)客戶選擇購買某圖書產(chǎn)品時(shí),應(yīng)該能夠?qū)?duì)應(yīng)圖書信息,如

81、:價(jià)格、圖書信息記錄到對(duì)應(yīng)的購物車中,并允許客戶返回書目查詢頁面,選擇其他商品,并添加到購物車中,當(dāng)對(duì)應(yīng)的購物訂單生成后,應(yīng)該能夠自動(dòng)清除以生成訂單的購物車中的信息。</p><p>  訂單處理:對(duì)應(yīng)客戶購買圖書商品信息的需求,在確定了所購圖書商品的價(jià)格、數(shù)量等信息后,提示用戶選擇對(duì)應(yīng)的送貨方式及付款方式,最終生成對(duì)應(yīng)的訂單記錄,以便于網(wǎng)站配貨人員依據(jù)訂單信息進(jìn)行后續(xù)的出貨、送貨的處理。也可以對(duì)訂單進(jìn)行修改等操

82、作。</p><p><b>  4.2 總體設(shè)計(jì)</b></p><p>  圖4.1系統(tǒng)功能結(jié)構(gòu)圖</p><p>  4.3各模塊具體功能說明</p><p>  4.3.1 注冊功能</p><p>  由于用戶購買的圖書必須通過郵寄,物流等手段送達(dá),所以用戶如果想通過該系統(tǒng)進(jìn)行圖書交易,

83、就必須要把一些必須的基本信息通過注冊的方式保存在系統(tǒng)中。</p><p>  要求用戶注冊的目的主要是為了方便發(fā)送貨物。</p><p>  為保證用戶帳號(hào)的唯一性,建議采用電子郵件地址作為ID。</p><p>  為方便用戶隨時(shí)更正不合理的數(shù)據(jù),要求系統(tǒng)提供及時(shí)的客戶校驗(yàn)提示功能。</p><p>  4.3.2 登錄功能</p&g

84、t;<p>  為了在用戶進(jìn)行圖書交易的時(shí)候確認(rèn)用戶ID,用戶在進(jìn)行圖書結(jié)算的時(shí)候,必須登錄。</p><p>  登錄的主要目的是通過ID確認(rèn)該用戶是否注冊,系統(tǒng)根據(jù)登錄用戶名的注冊信息進(jìn)行交易。</p><p>  登錄的時(shí)機(jī)可以在用戶訪問系統(tǒng)的時(shí)候,也可以在圖書結(jié)算的時(shí)候。同時(shí)為方便沒有注冊用戶的操作,在登錄頁面中可以進(jìn)行注冊功能選擇。注冊后的用戶自動(dòng)作為登錄用戶。&l

85、t;/p><p>  結(jié)算界面要求可以導(dǎo)航到用戶定單維護(hù)界面,方便用戶查看,維護(hù)定單。</p><p>  4.3.3 用戶相關(guān)信息維護(hù)功能</p><p><b>  用戶注冊信息維護(hù):</b></p><p>  用戶可以維護(hù)個(gè)人信息,修改注冊信息。主要是方便用戶隨時(shí)更改聯(lián)系方式。</p><p>

86、;<b>  用戶定單信息維護(hù):</b></p><p>  用戶可以在訂購商品后,對(duì)定單信息進(jìn)行維護(hù),包括查看歷史交易記錄。用戶可以修改,刪除還沒有發(fā)貨的商品記錄。</p><p>  4.3.4 商品瀏覽</p><p>  購物的最大樂趣就是瀏覽商品,在線購書系統(tǒng)必須提供用戶對(duì)商品進(jìn)行瀏覽的功能,用戶可以在不做任何購物決定的情況下隨意瀏覽

87、各種商品,要求系統(tǒng)對(duì)用戶瀏覽的商品提供最好的瀏覽效果和瀏覽的方便。</p><p>  用戶可以方便地通過商品名稱進(jìn)行查看。要求顯示記錄需要顯示商品名稱,圖片,價(jià)格,說明,生產(chǎn)廠家,生產(chǎn)日期等信息。</p><p>  我們在購物的時(shí)候也要挎一個(gè)購物藍(lán)或推一個(gè)購物車,在線購書系統(tǒng)要求在商品信息上提供購書功能。方便用戶隨時(shí)把書籍加入到購書清單中,以便最后進(jìn)行商品交易。</p>

88、<p>  4.3.5商品交易功能</p><p>  商品交易功能是本系統(tǒng)最核心的功能,也稱為購物車功能。該功能主要完成商品選購與結(jié)算。</p><p>  登錄用戶可以在查詢結(jié)果中選擇是否購物,購物商品臨時(shí)存放在購物車中,由用戶最后確認(rèn)并結(jié)算后再放入數(shù)據(jù)庫交易記錄。</p><p>  在結(jié)算得時(shí)候,提供商品數(shù)量錄入,允許用戶指定購買數(shù)量。用戶也可以在

89、結(jié)算前刪除預(yù)購買的商品。</p><p><b>  第五章 數(shù)據(jù)庫設(shè)計(jì)</b></p><p>  5.1 數(shù)據(jù)庫E-R圖</p><p>  數(shù)據(jù)庫總體E-R圖(如圖5.1):</p><p>  圖:5.1數(shù)據(jù)庫總體E-R圖</p><p>  數(shù)據(jù)庫E-R圖說明:</p>&

90、lt;p><b>  實(shí)體表:</b></p><p>  ● category:商品類別表、存放商品類別</p><p>  ● product:商品表、存放商品信息</p><p>  ● user:用戶密碼表、存放用戶名和密碼</p><p>  ● contactinfo:用戶詳細(xì)信息表、存放對(duì)應(yīng)用戶的詳細(xì)

91、信息</p><p>  ● orderstatus:訂單狀態(tài)表、保存訂單的狀態(tài)</p><p>  ● payway:付款方式表、存放可用的付款方式</p><p>  ● orders:訂單表、存放所有的訂單</p><p><b>  關(guān)系表:</b></p><p>  ● orderli

92、ne:訂單和商品關(guān)系表、保存訂單和商品的關(guān)聯(lián)關(guān)系</p><p>  5.2數(shù)據(jù)實(shí)體類結(jié)構(gòu)概要設(shè)計(jì)</p><p>  數(shù)據(jù)庫實(shí)體類結(jié)構(gòu)概要設(shè)計(jì)圖:</p><p>  圖5.2數(shù)據(jù)庫實(shí)體類結(jié)構(gòu)概要設(shè)計(jì)圖</p><p>  5.2.1 數(shù)據(jù)庫結(jié)構(gòu)設(shè)計(jì)UserInfo</p><p>  表5.1 UserInfo&

93、lt;/p><p>  5.2.2 數(shù)據(jù)庫結(jié)構(gòu)設(shè)計(jì)Produts</p><p>  表5.2 Produts</p><p>  5.2.3 數(shù)據(jù)庫結(jié)構(gòu)設(shè)計(jì)ProductType</p><p>  表5.3 ProductType</p><p>  5.2.4 數(shù)據(jù)庫結(jié)構(gòu)設(shè)計(jì)Transactions</p&

94、gt;<p>  表5.4 Transactions</p><p>  5.3數(shù)據(jù)庫的初始化及創(chuàng)建</p><p>  5.3.1數(shù)據(jù)庫的初始化</p><p><b>  ◆初始化代碼:</b></p><p>  -------------------------建立庫腳本</p>&

95、lt;p><b>  --刪除數(shù)據(jù)庫</b></p><p>  drop database if exists gwap;</p><p><b>  --創(chuàng)建數(shù)據(jù)庫</b></p><p>  create database if not exists gwap default character set gbk

96、;</p><p><b>  --切換數(shù)據(jù)庫</b></p><p><b>  use gwap;</b></p><p>  -------------------------創(chuàng)建表腳步</p><p><b>  --創(chuàng)建商品類別表</b></p><

97、;p>  create table category(</p><p>  categoryid numeric(10),</p><p>  name varchar(128) not null,</p><p>  description varchar(512),</p><p>  constraint category_id_

98、pk primary key(categoryid)</p><p><b>  );</b></p><p><b>  --創(chuàng)建商品表</b></p><p>  create table product (</p><p>  productid numeric(16),</p>

99、<p>  name varchar(64) not null,</p><p>  description varchar(4000),</p><p>  basePrice numeric(12,2) not null,</p><p>  categoryid numeric(10),</p><p>  author v

100、archar(128) not null,</p><p>  publish varchar(256) not null,</p><p>  pages numeric(6),</p><p>  images varchar(128),</p><p>  constraint product_id_pk primary key(pro

101、ductid)</p><p><b>  );</b></p><p><b>  --創(chuàng)建用戶密碼表</b></p><p>  CREATE TABLE users (</p><p>  userid varchar(16),</p><p>  password v

102、archar(12) not null,</p><p>  constraint users_userid_pk primary key(userid)</p><p><b>  );</b></p><p>  --創(chuàng)建用戶詳細(xì)信息表</p><p>  CREATE TABLE contactinfo (<

103、/p><p>  contactid numeric(20),</p><p>  userid varchar(16),</p><p>  street1 varchar(64) default NULL,</p><p>  street2 varchar(64) default NULL,</p><p>  ci

104、ty varchar(32) default NULL,</p><p>  province varchar(32),</p><p>  country varchar(32),</p><p>  zip varchar(8) default NULL,</p><p>  email varchar(32) default NULL,

105、</p><p>  homephone varchar(16) default NULL,</p><p>  cellphone varchar(16) default NULL,</p><p>  officephone varchar(16) default NULL,</p><p>  constraint contactinf

106、o_id_pk primary key(contactid)</p><p><b>  );</b></p><p><b>  --創(chuàng)建訂單狀態(tài)表</b></p><p>  CREATE TABLE orderstatus (</p><p>  statusid numeric(3),<

107、;/p><p>  name varchar(32) not null,</p><p>  description varchar(64) default NULL,</p><p>  constraint orderstatus_id_pk PRIMARY KEY (statusid)</p><p><b>  );</b

108、></p><p><b>  --創(chuàng)建付款方式表</b></p><p>  create table payway (</p><p>  paywayid numeric(3),</p><p>  paystyle varchar(64) not null,</p><p>  co

109、nstraint payway_id_pk primary key(paywayid)</p><p><b>  );</b></p><p><b>  --創(chuàng)建訂單表</b></p><p>  CREATE TABLE orders (</p><p>  orderid int auto_

110、increment,</p><p>  name varchar(32),</p><p>  cost numeric(15,3) not null,</p><p>  userid varchar(16),</p><p>  statusid numeric(3),</p><p>  paywayid nu

111、meric(3),</p><p>  CONSTRAINT orders_id_pk primary key(orderid)</p><p><b>  );</b></p><p>  --創(chuàng)建訂單和商品關(guān)系表</p><p>  CREATE TABLE orderline (</p><p&

112、gt;  lineid int auto_increment,</p><p>  orderid numeric(20),</p><p>  productid numeric(16),</p><p>  amount numeric(20,2) not null,</p><p>  constraint orderline_pk P

113、RIMARY KEY (lineid)</p><p><b>  );</b></p><p>  ◆初始化成功界面(如圖5.3):</p><p>  圖5.3初始化成功界面</p><p>  5.3.2 數(shù)據(jù)庫的創(chuàng)建</p><p><b>  ◆創(chuàng)建代碼:</b>&

114、lt;/p><p>  -------------------------初始化表腳步</p><p>  --初始化商品類別表</p><p>  insert into category(categoryid,name,description) values(1,'計(jì)算機(jī)', '軟件與程序設(shè)計(jì)相關(guān)');</p><

115、p>  insert into category(categoryid,name,description) values(2,'英語', '英語相關(guān)圖書');</p><p>  insert into category(categoryid,name,description) values(3,'文學(xué)', '文學(xué)作品圖書集');</p&

116、gt;<p><b>  --初始化商品表</b></p><p>  INSERT INTO product VALUES (1, 'JAVA編程思想:第3版', '......', 95,00, 1, '(美)Bruce Eckel', '機(jī)械工業(yè)出版社', 796, 'images/product/z

117、cover,gif');</p><p><b>  .........</b></p><p>  --初始化用戶密碼表</p><p>  INSERT INTO users VALUES ('admin', 'admin');</p><p>  --初始化用戶詳細(xì)信息表&l

118、t;/p><p>  INSERT INTO contactinfo VALUES (1, 'admin', '', '', '', 18, 1, '', '', '', '', '');</p><p>  --初始化訂單狀態(tài)表</p>

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲(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)論