毕业论文 - 张东龙 - 打印版(修改)

更新时间:2024-06-27 14:05:01 阅读量: 综合文库 文档下载

说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。

北 京 青 年 政 治 学 院

毕 业 论 文

题 目:网络书城平台管理系统 系 别:计算机系 专 业:计算机应用技术 姓 名:张冬龙 学 号:2009171133 指导教师:温绍洁

二O一二年 四 月 二十 日

北京青年政治学院

毕 业 设 计 任 务 书 2011 至 2012 学年 第 2 学期

学生姓名 专 业 指导教师 张冬龙 计算机应用技术 温绍洁 学 号 班 级 职称 副教授 2009171133 1班 教研室 计算机应用 毕业设计题目 网络书城平台管理系统 主要设计内容与基本要求 设计内容:设计一个网络书城平台管理系统,用JSP制作前台,采用Java Servlet 技术,基于MVC结构。后台数据库采用MySql5.5。 基本要求:解决人工管理过程中的管理效率低下、数据不准确、管理不及时等一系列问题, 提升高校的管理水平,使图书管理更加科学、合理。 任 务书内容 时间限定计划 2011年12月 至 2012年4月完成 1. 石志国. JSP网络开发详解. 电子工业出版社, 2007.70~77 2. 鲁晓东,杨健.JSP软件工程案例精解.北京:电子工业出推荐参 版社,2005.18~20 考资料 3. 吴建. 张旭东. JSP网络开发入门与实践. 人民邮电出版社,2006.100~120 指导教师意见 签名: 年 月 日 系部 意见 系主任签名: 年 月 日 摘要

随着网络技术的发展,Internet已成为最具市场潜力的技术领域,使用Web技术设计的数据库应用软件,是目前Internet市场的技术中坚,各种Web应用如电子商务,网上购物等都采用这种方式实现。

网上购书在国外已经是一个比较常见的购书方式了,而在我国,网上购书才是刚刚起步,但发展的速度却十分的惊人。本系统主要实现了用户的管理、书籍的查找与购买、订单的管理以及用户留言等功能,为用户提供了迅速、便利的网上购书环境。

本系统采用JSP、Servlet、JavaBean和JDBC等一些JAVA Web相关技术实现了一个简单的网上购书系统,MVC开发模式可以分离数据访问和数据表现,让开发人员可以开发一个可伸缩性强的、便于扩展的控制器,来维护整个流程。本系统通用性强,经过简单的修改就可以应用于更广泛的网上购物系统,具有一定的推广价值。

关键字:图书;数据库;JSP;Servlet;JavaBean

目录 目录

摘要 ........................................................................................................................................................ 3 目录 ........................................................................................................................................................ 1 第一章 绪论 ........................................................................................................................................... 1 1.1 背景 .................................................................................................................................................... 1 1.2 开发环境 ............................................................................................................................................ 2 1.3 相关技术 ............................................................................................................................................ 4

1.3.1 JSP的简介 ................................................................................................................................. 4 1.3.2 Tomcat ........................................................................................................................................ 6 1.3.3 MyEclipse .................................................................................................................................. 6 1.3.4 MySQL .......................................................................................................................................... 7 1.3.5 MySQL数据库服务器管理和开发工具:Navicat ................................................................... 8

第二章 需求分析 ................................................................................................................................... 9 2.1 需求分析的原因 ................................................................................................................................ 9 2.2 需求分析的任务 ................................................................................................................................ 9 2.3 实体-联系图 ...................................................................................................................................... 9

2.4.1 图书E-R图 ................................................................................................................................ 9 2.4.2 用户信息E-R图 ...................................................................................................................... 10 2.4.3 订单E-R图 .............................................................................................................................. 10 2.4.4 订单详细信息E-R图 .............................................................................................................. 11 2.4.5 图书分类E-R图 ...................................................................................................................... 11 2.4.6 用户留言E-R图 ...................................................................................................................... 11 2.4.7 公告信息E-R图 ...................................................................................................................... 12 2.4.8 网络书城管理实体间的联系图 .............................................................................................. 12

第三章 总体设计 ..................................................................................................................................13 3.1 设计目标 .......................................................................................................................................... 13 3.2系统体系结构设计 ........................................................................................................................... 13

3.2.1系统功能模块划分 ................................................................................................................... 13 3.2.2 系统结构图设计 ...................................................................................................................... 14 3.3 数据库设计 ...................................................................................................................................... 15 3.3.1 用户信息表 .............................................................................................................................. 15 3.3.2 图书信息表 .............................................................................................................................. 15 3.3.3 订单表 ...................................................................................................................................... 15 3.3.4 订单详细信息表 ...................................................................................................................... 15 3.3.5 图书大类信息表 ...................................................................................................................... 18 3.3.6 图书小类信息表 ...................................................................................................................... 18 3.3.7 用户留言信息表 ...................................................................................................................... 18 3.3.8 公告信息表 .............................................................................................................................. 19 3.3.9 管理员信息表 .......................................................................................................................... 19 3.4实体类设计 ....................................................................................................................................... 19

目录 第四章 系统详细设计 ......................................................................................................................... 37 4.1 系统功能设计 .................................................................................................................................. 37 4.2 用户注册模块设计 .......................................................................................................................... 37 4.3 用户登录模块设计 .......................................................................................................................... 37 4.4 图书信息模块设计 .......................................................................................................................... 39

4.4.1 图书展示模块设计 .................................................................................................................. 39

4.4.2 图书查询模块设计 .................................................................................................................. 39 4.5 购买图书模块设计 .......................................................................................................................... 39 4.6 管理员模块设计 .............................................................................................................................. 42 4.6.1 图书管理模块设计 .................................................................................................................. 42 4.6.2 会员管理模块设计 .................................................................................................................. 42 4.6.3 图书分类模块设计 .................................................................................................................. 43 4.6.4 公告信息模块设计 .................................................................................................................. 43 4.6.5 留言信息模块设计 .................................................................................................................. 43 4.6.6 订单信息模块设计 .................................................................................................................. 44

第五章 系统实现 ................................................................................................................................46 5.1实现用户注册模块 ........................................................................................................................... 46 5.2实现用户登录模块 ........................................................................................................................... 47 5.3 实现图书信息模块 .......................................................................................................................... 48

5.3.1 图书展示模块 .......................................................................................................................... 48 5.3.2 图书查询模块 .......................................................................................................................... 49 5.4 实现购买图书模块 .......................................................................................................................... 50 5.5 实现公告信息模块 .......................................................................................................................... 52 5.6 实现用户留言模块 .......................................................................................................................... 53 5.7 实现管理员模块 .............................................................................................................................. 53 5.7.1 图书管理模块 .......................................................................................................................... 53 5.7.2 会员管理模块 .......................................................................................................................... 55 5.7.3 订单信息模块 .......................................................................................................................... 58 5.7.4 公告信息模块 .......................................................................................................................... 60 5.8 系统的测试与维护 .......................................................................................................................... 61 5.8.1 单元测试 .................................................................................................................................. 61 5.8.2 系统维护 .................................................................................................................................. 62

总结 .......................................................................................................................................................63 参考文献 ...............................................................................................................................................65 致 谢 ...................................................................................................................................................66

第一章 绪论

第一章 绪论

随着科技飞速的发展,人类使用和学习信息的方式以及信息的包装方式正在进行着不可阻挡的革命,这次革命将比印刷术的出现所产生的影响以及对社会发展的推动更加复杂更加巨大。网站也成为人们最简便和喜爱的交流方式和传递信息的手段,尤其在商品交易方面,人们更是寻求最佳简便的消费方式。

网络书城具有很多新的特性,以下这些是它的优势: 1.其营业成本完全有理由比传统意义上的书店低得多。 2.不需支付昂贵的店铺租金,花费浩大的装修。

3.不需要将大笔的流动资金作为货物而沉积在店里,可依靠“零库存”管理,缩短资金周转的周期,可以加速周转。

4.同时可以实现24小时营业,不需要营业员,网上书店可以被设置成一个自动售货机。

5.依靠客户数据库能够提供全新的个人化服务等。 以上这些特性使网上商店充满生命力,也是它发展的源动力。

1.1 背景

1.网络书城平台管理系统的发展

Internet 的迅速发展正以前所未有的深度和广度影响和改善着人类生活的各个方面,越来越多的人开始意识到Internet所蕴含的经济价值的无穷商机,并积极投身于电子商务活动。实际上,电子商务是一些商业行为的电子化,例如网上书店,网上贸易,就网上书店来说,网上书店是目前应用最广,最成功的典范之一,网上书店的崛起对传统的图书流通体系产生了强烈的冲击,有效地缩短了图书流通发行环节,将广大读者,图书,出版者,发行者紧密地结合在一起,大大提高了图书流通率[1]。

2.网上书店系统发展现状

西方国家网上书店概况:世界上第一家网上书店是1991年在美国联机公司AOL采购网络上建立的“阅读美国书店”,目前最有名的是美国西雅图亚马逊图书公司的亚马逊网上书店。它创建于1995年,供书达310余万种,每年顾客达500万人

1

第一章 绪论 次,其价格优惠20%-30%。

2.网络书城系统发展现状

金融结算制度完善,配送服务高效。实现了零库存运转。英国网上书店中较著名的有Internet书店,德国的网上书店主要有图书在线网上书店。

国内网上书店的概况:自从亚马逊网上书店成功后,中国的网上书店也建立起来。中国最早的网上书店是1997年在杭州新华书店诞生的,在经过年余的艰苦经营,接待了400多位访问者后,悄然引退,而进入1998年后,作为中国书业传统经营力量的新华书店,正式宣布进入网络领域,先是第九届全国书市首次开通书店网站,后来在1998年12月30日上海书城成为国内首家正规的网上书店,读者在家中可以上网完成浏览,选够,付款的全过程。1999年是网上书店迅速发展的一年,商业公司不断进入网上书店有超过几百家,有自己网站的公司有40多家,这个数目还不断增加。

3.网络书城的优越性

网上书店在价格、时效性、品种、查询方式等方面都有优势。网上书店是一种直销方式,在到书速度和价格上都有优势,目前网上书店的到书时间在北京,上海,广州等大城市一般为1-3天,在外埠则一般3-10天到书,在价格上一般网上书店都有7.5-9折的折扣,如果是特价书折扣就更多了,网上书店的书目数据是任何订购书目都无法比拟的,亚马逊网上书店有300多万种图书,另外还有音乐系列产品和其它教育产品,刚刚成立的北京图书大厦网上书店也有16万种书目数据,“中国寻书网”目前也有50万种书籍,年度将突破100万种图书,网上书店的书目除书名,著者,价格等信息外,还有封面,内容简介,目次,评论等详细信息。同时网上书店的目录查询功能也是传统的按某种分类规则编排的图书征订目录无法比拟的,其以关键词或主题从网上检索某类文献,查准率与查全率都有一定的保障。另外还有一些书更是以网站包销或总代理的形式进行销售,这就意味着一种全新的电子商务模式的开始[2]。

1.2 开发环境

1.开发环境的选择会影响到数据库的设计,所以在这里给出网上书店开发与运行环境的选择如下:

开发环境:Windows XP。 开发工具:MyEclipse 6.5。

2

第一章 绪论 数据库管理系统: MySQL 5.5。 设计模式:MVC设计模式。 2.使用MVC设计模式的优点

大部分用过程语言比如ASP、PHP开发出来的Web应用,初始的开发模板就是混合层的数据编程。例如,直接向数据库发送请求并用HTML显示,开发速度往往比较快,但由于数据页面的分离不是很直接,因而很难体现出业务模型的样子或者模型的重用性。产品设计弹性力度很小,很难满足用户的变化性需求。MVC要求对应用分层,虽然要花费额外的工作,但产品的结构清晰,产品的应用通过模型可以得到更好地体现。

首先,最重要的是应该有多个视图对应一个模型的能力。在目前用户需求的快速变化下,可能有多种方式访问应用的要求。例如,订单模型可能有本系统的订单,也有网上订单,或者其他系统的订单,但对于订单的处理都是一样,也就是说订单的处理是一致的。按MVC设计模式,一个订单模型以及多个视图即可解决问题。这样减少了代码的复制,即减少了代码的维护量,一旦模型发生改变,也易于维护。 其次,由于模型返回的数据不带任何显示格式,因而这些模型也可直接应用于接口的使用。

再次,由于一个应用被分离为三层,因此有时改变其中的一层就能满足应用的改变。一个应用的业务流程或者业务规则的改变只需改动MVC的模型层。

控制层的概念也很有效,由于它把不同的模型和不同的视图组合在一起完成不同的请求,因此,控制层可以说是包含了用户请求权限的概念。

最后,它还有利于软件工程化管理。由于不同的层各司其职,每一层不同的应用具有某些相同的特征,有利于通过工程化、工具化产生管理程序代码

3.MVC模式设计思想 MVC设计思想概论。

MVC英文即Model-View-Controller,即把一个应用的输入、处理、输出流程按照Model、View、Controller的方式进行分离,这样一个应用被分成三个层——模型层、视图层、控制层。

(1)MVC中的M组件。模型(Model):就是业务流程/状态的处理以及业务规则的制定。业务流程的处理过程对其它层来说是黑箱操作,模型接受视图请求的数据,并返回最终的处理结果。业务模型的设计可以说是MVC最主要的核心。

3

第一章 绪论 (2)MVC中的V组件。视图(View)代表用户交互界面,用JSP来实现。 (3)MVC中的C组件。控制(Controller)可以理解为从用户接收请求,将模型与视图匹配在一起,共同完成用户的请求。

MVC中各组件的关系。

模型、视图与控制器的分离,使得一个模型可以具有多个显示视图。如果用户通过某个视图的控制器改变了模型的数据,所有其它依赖于这些数据的视图都应反映到这些变化。因此,无论何时发生了何种数据变化,控制器都会将变化通知所有的视图,导致显示的更新。这实际上是一种模型的变化-传播机制。模型、视图、控制器三者之间的关系和各自的主要功能,如图1-1所示。

图1-1 MVC组件类型的关系和功能

1.3 相关技术

网络书城平台管理系统的实现技术多种多样,所以选择合理的技术来实现系统也是一个重大的环节,如果所选择的技术不当,将对系统的实现造成一定的麻烦,可能还会影响系统的性能。J2EE是实现企业仓库管理系统的一种有效技术,当前用J2EE实现B/S结构的网络书城平台管理系统非常的流行且技术也越来越趋于成熟,性能也得到了非常大的提升[10]。轻量级的J2EE应用对于小中型项目的开发带来了许多便利之处,对比于经典J2EE的简化,在保留经典J2EE应用的框架、良好的可扩展性、可维护性的基础上,简化了J2EE应用的开发,降低了J2EE应用的部署成本,基本实现过程简单明了。轻量级J2EE应用面向的是用户,是一种更实际的信息化平台架构[11]。

1.3.1 JSP的简介

1.JSP的简单介绍

4

第一章 绪论 JSP技术使用Java编程语言编写类XML的tags和scriptlets,来封装产生动态网页的处理逻辑。网页还能通过tags和scriptlets访问存在于服务端的资源的应用逻辑。JSP将网页逻辑与网页设计和显示分离,支持可重用的基于组件的设计,使基于Web的应用程序的开发变得迅速和容易。

Web服务器在遇到访问JSP网页的请求时,首先执行其中的程序段,然后将执行结果连同JSP文件中的HTML代码一起返回给客户。插入的Java程序段可以操作数据库、重新定向网页等,以实现建立动态网页所需要的功能。

JSP与Java Servlet一样,是在服务器端执行的,通常返回给客户端的就是一个HTML文本,因此客户端只要有浏览器就能浏览。

JSP页面由HTML代码和嵌入其中的Java代码所组成。服务器在页面被客户端请求以后对这些Java代码进行处理,然后将生成的HTML页面返回给客户端的浏览器。Java Servlet 是JSP的技术基础,而且大型的Web应用程序的开发需要Java Servlet和JSP配合才能完成。JSP具备了Java技术的简单易用,完全的面向对象,具有平台无关性且安全可靠,主要面向因特网的所有特点[3]。

自JSP推出后,众多大公司都支持JSP技术的服务器,如IBM、Oracle、Bea公司等,所以JSP迅速成为商业应用的服务器端语言。

JSP可用一种简单易懂的等式表示为:HTML+Java =JSP。 2.JSP技术的优点

基于JSP的各种优势,其优点如下:

(1)一次编写,到处运行。除了系统之外,代码不用做任何更改。

(2)系统的多平台支持。基本上可以在所有平台上的任意环境中开发,在任意环境中进行系统部署,在任意环境中扩展。相比ASP/.net的局限性是显而易见的。 (3)强大的可伸缩性。从只有一个小的Jar文件就可以运行Servlet/JSP,到由多台服务器进行集群和负载均衡,到多台Application进行事务处理,消息处理,一台服务器到无数台服务器,Java显示了一个巨大的生命力。

(4)多样化和功能强大的开发工具支持。这一点与ASP很像,Java已经有了许多非常优秀的开发工具,而且许多可以免费得到,并且其中许多已经可以顺利的运行于多种平台之下。

(5)支持服务器端组件。web应用需要强大的服务器端组件来支持,开发人员需要利用其他工具设计实现复杂功能的组件供web页面调用,以增强系统性能。JSP

5

第一章 绪论 可以使用成熟的JAVABEANS 组件来实现复杂商务功能。

3.JSP技术的缺点

Java的一些优势正是它致命的问题所在,因此JSP有如下缺点:

(1)由于为了跨平台的功能,为了极度的伸缩能力,所以极大的增加了产品的复杂性。

(2)Java的运行速度是用class常驻内存来完成的,所以它在一些情况下所使用的内存比起用户数量来说确实是“最低性能价格比”了。从另一方面,它还需要硬盘空间来储存一系列的.java文件和.class文件,以及对应的版本文件。

1.3.2 Tomcat

Tomcat 很受广大程序员的喜欢,因为它运行时占用的系统资源小,扩展性好,支持负载平衡与邮件服务等开发应用系统常用的功能;而且它还在不断的改进和完善中,任何一个感兴趣的程序员都可以更改它或在其中加入新的功能。

Tomcat 是一个小型的轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP 程序的首选[6]。对于一个初学者来说,可以这样认为,当在一台机器上配置好Apache 服务器,可利用它响应对HTML 页面的访问请求。实际上Tomcat 部分是Apache 服务器的扩展,但它是独立运行的,所以当你运行Tomcat 时,它实际上作为一个与Apache 独立的进程单独运行的。

当配置正确时,Apache 为HTML页面服务,而Tomcat 实际上运行JSP 页面和Servlet。另外,Tomcat和IIS、Apache等Web服务器一样,具有处理HTML页面的功能,另外它还是一个Servlet和 JSP容器,独立的Servlet容器是Tomcat的默认模式。不过,Tomcat处理静态HTML的能力不如Apache服务器。2。

1.3.3 MyEclipse

1.MyEclipse的简单介绍

MyEclipse企业级工作平台(MyEclipse Enterprise Workbench,简称MyEclipse)是对Eclipse IDE的扩展,利用它我们可以在数据库和JavaEE的开发、发布,以及应用程序服务器的整合方面极大的提高工作效率。它是功能丰富的JavaEE集成开发环境,包括了完备的编码、调试、测试和发布功能,完整支持HTML、Struts、JSP、CSS、Javascript、SQL和 Hibernate。

2.MyEclipse的分类

在结构上,MyEclipse的特征可以被分为7类:

6

第一章 绪论 (1)JavaEE模型 。 (2)WEB开发工具 。 (3)EJB开发工具 。

(4)应用程序服务器的连接器 。 (5)JavaEE项目部署服务 。 (6)数据库服务 。 (7)MyEclipse整合帮助 。

对于以上每一种功能上的类别,在Eclipse中都有相应的功能部件,并通过一系列的插件来实现它们。MyEclipse结构上的这种模块化,可以让我们在不影响其他模块的情况下,对任一模块进行单独的扩展和升级。

简单而言,MyEclipse是Eclipse的插件,也是一款功能强大的JavaEE集成开发环境,支持代码编写、配置、测试以及除错,MyEclipse6.0以前版本需先安装Eclipse。MyEclipse6.0以后版本安装时不需安装Eclipse。

1.3.4 MySQL

MySQL是一个小型关系型数据库管理系统,开发者为瑞典MySQL AB公司。在2008年1月16号被Sun公司收购。而2009年,SUN又被Oracle收购。对于MySQL的前途,没有任何人抱乐观的态度。目前MySQL被广泛地应用在Internet上的中小型网站中。由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库。

MySQL的特性包括:

(1)使用C和C++编写,并使用了多种编译器进行测试,保证源代码的可移植性。 (2)支持AIX、FreeBSD、HP-UX、Linux、Mac OS、Novell Netware、OpenBSD、OS/2 Wrap、Solaris、Windows等多种操作系统。

(3)为多种编程语言提供了API。这些编程语言包括C、C++、Python、Java、Perl、PHP、Eiffel、Ruby和Tcl等。

(4)支持多线程,充分利用CPU资源。

(5)优化的SQL查询算法,有效地提高查询速度。

(6)既能够作为一个单独的应用程序应用在客户端服务器网络环境中,也能够作为一个库而嵌入到其他的软件中提供多语言支持,常见的编码如中文的GB2312、BIG5,日文的Shift_JIS等都可以用作数据表名和数据列名。

7

第一章 绪论 (7)提供TCP/IP、ODBC和JDBC等多种数据库连接途径。 (8)提供用于管理、检查、优化数据库操作的管理工具。 (9)可以处理拥有上千万条记录的大型数据库。

1.3.5 MySQL数据库服务器管理和开发工具:Navicat

Navicat MySQL是一个强大的MySQL数据库服务器管理和开发工具。它可以与任何3.21或以上版本的MySQL一起工作,并支持大部分的MySQL最新功能,包括触发器、存储过程、函数、事件、视图、管理用户等。它不仅对专业开发人员来说是非常尖端的技术,而且对于新手来说也易学易用。其精心设计的图形用户界面(GUI),Navicat MySQL可以让你用一种安全简便的方式快速并容易地创建,组织,访问和共享信息。

Navicat MySQL在三种平台上是可用的——微软Windows、Mac OS X 和Linux操作系统。它可以使用户连接到本地/远程服务器,提供了几种实用工具,例如数据结构同步、导入/导出、备份和报告,使维护数据的过程很容易。

自从2001年初以来,Navicat在全世界范围内已被下载了数百万次;Navicat是公认最受欢迎的MySQL前端图形用户界面,而且它对于本地或远程的MySQL管理和开发,在三种操作系统平台上——Windows、Mac OS X和Linux都是可用的。在过去的5年中,Navicat已在最好的服务器管理工具类别的几个奖项中被提名,并且被许多托管公司选为一种标准的托管工具,例如Rackspace公司,是最成功的管理托管公司之一。

8

第二章 需求分析

第二章 需求分析

2.1 需求分析的原因

根据现在社会上对网络书店的需求,为了开发出真正满足用户需求的产品——网上书店,首先必须要知道客户的需求。对软件需求的深入理解是软件开发工作获得成功的前提条件,不论我们把设计和编码工作做得如何出色,不能满足用户需求的程序只会给客户带来失望,给开发带来麻烦。虽然在可行性研究阶段已经粗略了解用户的需求,甚至还提出了一些可行的方案,但是,可行性研究的基本目的使用较小的成本在较短时间内确定是否存在可行的解法,因此,在需求分析阶段要确定系统必须完成哪些工作,也就是对系统提出完整、准确、清晰、具体的要求。

2.2 需求分析的任务

通过对系统的分析及对其他网店的参考,基本确定了“网络书城”的基本功能以及基本性能的基本需求。

功能需求:这方面的需求指定系统必须提供的服务,通过需求分析应该划分出系统必须完成的所有功能。其功能如下:

(1)图书信息管理,主要有修改图书信息、添加图书、删除图书。 (2)图书销售管理,主要包括:图书查找、订单提交。 (3)用户管理,主要有用户注册、修改用户信息、删除用户。 (4)留言管理,主要有用户留言和管理员删除用户的留言。 (5)公告信息,主要有发布公告、修改公告、删除公告。 (6)订单管理,主要有订单的修改,删除订单。

性能需求:指定系统必须满足的定时约束或容量约束,通常包括速度(响应时间)、信息量速率、主存容量、磁盘容量、安全性等方面的要求。其要求如下:

(1)用户在客户端点击存在服务器中的主页时,系统能快速响应。 (2)在安全性方面,JSP程序要满足客户传输信息的基本安全。

2.3 实体-联系图

2.4.1 图书E-R图

图书的属性包括:图书编号、书名、作者、出版社、出版时间、图片、图书价

格、图书分类、图书简介、推荐数和图书数量等。图书的E-R图如图2-1所示。

9

第二章 需求分析 图书数量 图书编号 书 名 作 者 推荐数 图 书 图书简介 出版社 出版时间 图书分类 图书价格 图书图片

图2-1 图书E-R图

2.4.2 用户信息E-R图

用户的属性包括:用户ID、用户名、用户密码、真实姓名、用户性别、联系电话、通讯地址、邮政编码、电子邮件、找密问题提示、问题答案等。其E-R图如图2-2所示。

用户ID 问题答案 真实姓名 找密提示 用 户 用户性别 用户名 用户密码 电子邮件 邮政编码 通讯地址 联系电话 图2-2 用户E-R图

2.4.3 订单E-R图

订单的属性包括:订单ID、用户、收货人、收货地址、联系电话、邮政编码、订单日期、总价。其E-R图如图2-3所示。

10

第三章 总体设计 所示。

编号 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 字段名 id name password email trueName sex birthday address postcode phone mphone question answer img score 中文含义 编号 用户名 密码 邮箱 真实名字 性别 生日 地址 邮编 电话 手机 问题 答案 头像 积分 键值 主键 类型长度 Int(11) Varchar(30) Varchar(16) Varchar(50) Varchar(40) Varchar(30) Varchar(20) Varchar(100) Varchar(10) Varchar(15) Varchar(15) Varchar(30) Varchar(30) Varchar(100) Int(11) 缺省 可空 N N N N N Y Y 说明 自动增加 表3-2用户信息表(tb_user)

编号 1 2 3 4 5 6 字段名 bookId superTypeId subTypeId bookName ISBN introduce 中文含义 编号 大类ID 小类ID 图书名称 ISBN 说明 键值 主键 外键 外键 16

类型长度 Int(11) Int(11) Int(11) Varchar(200) Varchar(20) Text 缺省 可空 N N N Y Y Y 说明 自动增加 第三章 总体设计 7 8 9 10 11 12 13 14 15 16 17 18 Price nowPrice picture pages publisher author inTime newBooks saleBooks hostBooks bookNum 价格 最新价格 图片地址 图书页数 出版社 作者 Float Float Varchar(200) Int(11) Varchar(40) Varchar(20) Y Y Y Y Y Y N Y Y Y Y 上架时间 系统时间 timestamp 最新图书 畅销图书 主页图书 图书数量 Int(11) Int(11) Int(11) Int(11) Int(11) specialBooks 特别推荐 表3-3 图书信息表(tb_book)

编号 1 2 3 4 5 6 字段名 orderItemId orderId bookId bookName price bookNum 中文含义 键值 编号 订单ID 图书ID 名称 价格 数量 主键 类型长度 Int(111) Int(11) Int(11) Varchar(50) Float Int(11) 缺省 可空 N N Y Y Y N 说明 表3-4 订单表(tb_orderitem)

编号 1 2 3 4 5 6 7 字段名 orderId name recvName address postcode orderDate email 中文含义 编号 名称 接受者 地址 邮编 时间 邮箱 键值 主键 类型长度 Int(11) Varchar(20) Varchar(20) Varchar(255) Varchar(10) timestamp DateTime(8) 17

缺省 可空 N N N N N N Y 说明 自动增加 第三章 总体设计 8

flag 发货情况 Int(11) 表3-5 订单详细信息表(tb_order) 3.3.5 图书大类信息表

图书分类信息表的字段包括:分类编号和分类名称。其数据表如表3-6所示。 编号 1 2 字段名 typeName 中文含义 名称 键值 主键 类型长度 Int(11) Varchar(50) 缺省 可空 N N 说明 superTypeId 编号 表3-6 图书大类信息表(tb_supertype)

3.3.6 图书小类信息表

图书分类信息表的字段包括:小类编号、父类编号和小类名称。其数据表如表3-7所示。 编号 1 2 2 字段名 subTypeId subTypeName 中文含义 编号 名称 键值 主键 类型长度 Int(11) Int(11) Varchar(50) 缺省 可空 N N 说明 superTypeId 父类ID 表3-7 图书小类信息表(tb_subtype)

3.3.7 用户留言信息表

用户留言信息表包括的字段有:留言ID、留言内容、图片、创建日期等。其数据表如表3-8所示。

编号 1 2 3 4 5 6 字段名 id title author content ly_time imgs 中文含义 编号 名称 作者 内容 时间 图片 键值 主键 类型长度 Int(4) Varchar(20)) Varchar(20) Varchar(50) timestamp Varchar(20) 缺省 可空 N Y Y Y N Y 说明 自动增加 表3-8 用户留言信息表(tb_note)

18

第三章 总体设计 3.3.8 公告信息表

公告信息数据表的字段包括:公告ID、公告标题、公告内容、发布时间。其数据表如表3-9所示。

编号 1 2 3 4 字段名 informId informTitle informContent informTime 中文含义 编号 名称 内容 时间 键值 主键 类型长度 Int(11) Varchar(30) Varchar(30) timestamp 缺省 可空 N N 说明 自动增加 表3-9 公告信息表(notice)

3.3.9 管理员信息表

公告信息数据表的字段包括:用户与密码。其数据表如表3-10所示。

编号 1 2 字段名 Name Password 中文含义 键值 名称 密码 类型长度 Varchar(20) Varchar(50) 缺省 可空 N N 说明 表3-10 管理员信息表(tb_admin)

3.4实体类设计

1.Admin 管理员信息实体类

package com.zdl.shopping.po; public class Admin {

private String Name; private String Password; public String getName() { }

public void setName(String name) { }

public String getPassword() { }

return Password; Name = name; return Name;

19

第三章 总体设计 public void setPassword(String password) { Password = password;

}

}

2.Book图书信息实体类

package com.zdl.shopping.po; /**

*描述书的JavaBean */

public class Book { private int bookId; private int superTypeId; private int subTypeId; private String bookName; private String introduce; private float price; private float nowPrice; private String picture;

private int pages;

private String publisher; private String author; private String ISBN; private String inTime; private int newBooks; private int saleBooks; private int hostBooks; private int specialBooks;

private int bookNum;

20

第三章 总体设计

public int getBookId() { }

public void setBookId(int bookId) { }

public String getBookName() { }

public void setBookName(String bookName) { }

public int getBookNum() { }

public void setBookNum(int bookNum) { }

public int getHostBooks() { }

public void setHostBooks(int hostBooks) { }

public String getInTime() { }

public void setInTime(String inTime) { }

this.inTime = inTime; return inTime;

this.hostBooks = hostBooks; return hostBooks; this.bookNum = bookNum; return bookNum;

this.bookName = bookName; return bookName; this.bookId = bookId; return bookId;

21

第三章 总体设计

public String getIntroduce() { }

public void setIntroduce(String introduce) { }

public int getNewBooks() { }

public void setNewBooks(int newBooks) { }

public float getNowPrice() { }

public void setNowPrice(float nowPrice) { }

public String getPicture() { }

public void setPicture(String picture) { }

public float getPrice() { }

public void setPrice(float price) { }

this.price = price; return price;

this.picture = picture; return picture;

this.nowPrice = nowPrice; return nowPrice;

this.newBooks = newBooks; return newBooks;

this.introduce = introduce; return introduce;

22

第三章 总体设计 public int getSaleBooks() { return saleBooks;

}

public void setSaleBooks(int saleBooks) { this.saleBooks = saleBooks; }

public int getSubTypeId() { return subTypeId;

}

public void setSubTypeId(int subTypeId) { this.subTypeId = subTypeId; }

public int getSuperTypeId() { return superTypeId;

}

public void setSuperTypeId(int superTypeId) { this.superTypeId = superTypeId; }

public String getAuthor() { return author;

}

public void setAuthor(String author) { this.author = author; }

public String getISBN() { return ISBN;

}

public void setISBN(String isbn) { ISBN = isbn; }

23

第三章 总体设计 public int getPages() { return pages;

}

public void setPages(int pages) { this.pages = pages; }

public String getPublisher() { return publisher; }

public void setPublisher(String publisher) { this.publisher = publisher; }

public int getSpecialBooks() { return specialBooks;

}

public void setSpecialBooks(int specialBooks) { this.specialBooks = specialBooks; }

}

3.Inform 公告信息实体类

package com.zdl.shopping.po; public class Inform { private int informId; private String informTitle; private String informContent; private String informTime;

public String getInformContent() { return informContent;

}

24

第三章 总体设计 public void setInformContent(String informContent) { this.informContent = informContent;

}

public int getInformId() { return informId;

}

public void setInformId(int informId) { this.informId = informId; }

public String getInformTime() { return informTime;

}

public void setInformTime(String informTime) { this.informTime = informTime; }

public String getInformTitle() { return informTitle;

}

public void setInformTitle(String informTitle) { this.informTitle = informTitle; }

}

4.Note 留言信息实体类

package com.zdl.shopping.po; public class Note { private int id; private String title; private String author;

private String content;

25

第三章 总体设计 private String imgs; private String ly_time; public String getLy_time() { }

public void setLy_time(String ly_time) { return ly_time;

this.ly_time = ly_time; }

public String getAuthor() { return author;

}

public void setAuthor(String author) { this.author = author; }

public String getContent() { return content; }

public void setContent(String content) { this.content = content; }

public int getId() { return id;

}

public void setId(int id) { this.id = id; }

public String getImgs() { return imgs; }

public void setImgs(String imgs) {

26

第三章 总体设计

}

this.imgs = imgs;

public String getTitle() { }

public void setTitle(String title) { } }

this.title = title; return title;

5.Order订单信息实体类

package com.zdl.shopping.po; import java.util.List; /**

* 一个订单的JavaBean */

public class Order {

private int orderId;

private String recvName;//收货人 private User user; private String address; private String postcode; private String email; private String orderDate;

private int flag;//0表示货没发出,1表示货已发出,2表示货冻结 private List orderItem; //一个用于装订单项的List public List getOrderItem() { }

public void setOrderItem(List orderItem) {

return orderItem;

27

第三章 总体设计 this.orderItem = orderItem;

}

public int getFlag() { return flag;

}

public void setFlag(int flag) { this.flag = flag; }

public String getOrderDate() { return orderDate; }

public void setOrderDate(String orderDate) { this.orderDate = orderDate; }

public int getOrderId() { return orderId;

}

public void setOrderId(int orderId) { this.orderId = orderId; }

public User getUser() { return user;

}

public void setUser(User user) { this.user = user; }

public String getAddress() { return address; }

public void setAddress(String address) {

28

第三章 总体设计 }

this.address = address;

public String getEmail() { }

return email;

public void setEmail(String email) { this.email = email; }

public String getPostcode() { return postcode; }

public void setPostcode(String postcode) { this.postcode = postcode; }

public String getRecvName() { return recvName;

}

public void setRecvName(String recvName) { this.recvName = recvName; }

}

6.SubType 图书小类实体类

package com.zdl.shopping.po; public class SubType { private int subTypeId; private int superTypeId; private String typeName; public int getSubTypeId() {

return subTypeId;

29

第三章 总体设计 }

public void setSubTypeId(int subTypeId) { this.subTypeId = subTypeId;

}

public int getSuperTypeId() { return superTypeId;

}

public void setSuperTypeId(int superTypeId) { this.superTypeId = superTypeId; }

public String getTypeName() { return typeName;

}

public void setTypeName(String typeName) { this.typeName = typeName; }

}

7. SuperType 图书大类实体类

package com.zdl.shopping.po; public class SuperType { private int superTypeId; private String typeName; public int getSuperTypeId() { return superTypeId;

}

public void setSuperTypeId(int superTypeId) { this.superTypeId = superTypeId; }

public String getTypeName() {

30

第三章 总体设计 }

return typeName;

public void setTypeName(String typeName) { this.typeName = typeName;

}

}

8. User 会员信息实体类

package com.zdl.shopping.po; /**

* 描述用户的JavaBean */

public class User { private int id; private String name; private String password; private String email; private String trueName; private String sex; private String birthday; private String address; private String postcode; private String phone; private String mphone; private String question; private String answer; private String img; private int score;

public String getAddress() {

return address;

31

第三章 总体设计 }

public void setAddress(String address) { this.address = address;

}

public String getAnswer() { return answer;

}

public void setAnswer(String answer) { this.answer = answer; }

public String getBirthday() { return birthday; }

public void setBirthday(String birthday) { this.birthday = birthday; }

public String getEmail() { return email;

}

public void setEmail(String email) { this.email = email; }

public String getMphone() { return mphone; }

public void setMphone(String mphone) { this.mphone = mphone; }

public String getPhone() {

return phone;

32

第三章 总体设计 }

public void setPhone(String phone) { this.phone = phone;

}

public String getPostcode() { return postcode; }

public void setPostcode(String postcode) { this.postcode = postcode; }

public String getQuestion() { return question;

}

public void setQuestion(String question) { this.question = question; }

public String getSex() { return sex;

}

public void setSex(String sex) { this.sex = sex; }

public String getTrueName() { return trueName; }

public void setTrueName(String trueName) { this.trueName = trueName; }

public int getId() {

return id;

33

第三章 总体设计 }

public void setId(int id) { this.id = id;

}

public String getName() { return name; }

public void setName(String name) { this.name = name; }

public String getPassword() { return password; }

public void setPassword(String password) { this.password = password; }

public String getImg() { return img;

}

public void setImg(String img) { this.img = img; }

public int getScore() { return score; }

public void setScore(int score) { this.score = score; }

}

9. OrderItem 订单详细信息实体类

34

第三章 总体设计 package com.zdl.shopping.po; public class OrderItem { private int orderItemId; private int orderId; private int bookId; private String bookName; private float price; private int bookNum; public int getBookId() { return bookId;

}

public void setBookId(int bookId) { this.bookId = bookId; }

public String getBookName() { return bookName; }

public void setBookName(String bookName) { this.bookName = bookName; }

public int getBookNum() { return bookNum;

}

public void setBookNum(int bookNum) { this.bookNum = bookNum; }

public int getOrderId() { return orderId;

}

public void setOrderId(int orderId) {

35

本文来源:https://www.bwwdw.com/article/y883.html

Top