1、河北农业大学本科毕业论文(设计)题目:汽车销售管理系统的设计与实现-销售管理模块摘要本论文的目的是满足目前汽车销售企业管理销售信息的需求,来构建一个汽车销售信息管理模块。该汽车销售信息管理模块改变了原来传统纸质订单不好管理销售信息的局面,使用这种先进的管理方法能够提高销售数据的准确性,而且还能够大大提高销售信息管理人员的工作效率。本文介绍了实现汽车销售信息管理模块的总体框架,该模块采用J2EE技术进行开发,同时还采用三层B/S(Browser/Server)结构,该结构的采用使得数据结构集合能够在浏览器中显示,而数据的处理在服务器上进行,用户通过浏览器就能使用本模块的功能。本模块采用的数据库是
2、Mysql,并且使用JSP技术,使用户界面更加简洁友好,方便操作。本模块完成了管理员对销售订单和退货订单的管理以及修改汽车库存的功能。管理员可以对退货订单进行添加、删除、修改、查询的操作,同时对于销售订单也能进行添加、删除、修改、查询的操作。库存管理主要是进行退货订单入库,销售订单出库的操作,从而实现对汽车库存进行修改的功能。关键词:销售管理模块,J2EE,JSP,MysqlAbstract The purpose of this paper is to meet the needs of management informationsales car sales enterprises, t
3、o build a car sales information management module. The car sales information management module changed thetraditional paper orders not good sales information management in the situation, the use of this advanced management method to improve the accuracy of sales data, but also can greatly improve th
4、e sales information management personnels working efficiency.This paper introduces the overall framework for the realization of auto salesinformation management module, the module uses J2EE technology development, at the same time also adopts three layer B/S (Browser/Server)structure, this structure
5、 makes the collection of data structures can bedisplayed in the browser, and the data processing in the server, the user use the module through the browser will be able to function. This module uses the database is Mysql, and the use of JSP technology, the user interface morefriendly, convenient ope
6、ration.This module implements the administrator of the sales order and return order management and modify the motor function of inventory. Administrators can add, delete, modify, query operation to return the order, at the same time for the sales order can also add, delete, modify, query operation.
7、Inventory management is mainly the return order receipts, sales order deliveryoperation, so as to realize the function of modified car inventory.Key Words:Sales Management Module,J2EE,JSP,Mysql目录1 概述11.1开发背景11.2设计目的及内容11.2.1设计目的11.2.2设计内容11.3 技术概述11.3.1 B/S模式简介11.3.2 JSP技术简介21.3.3 Mysql简介21.3.4 MVC模
8、式简介21.4开发环境概述31.5系统开发命名规则31.5.1命名规则32 系统可行性研究和需求分析42.1可行性分析42.1.1 技术可行性42.1.2 经济可行性42.1.3 运行可行性42.1.4 法律可行性42.2 需求分析42.2.1 系统需求52.2.2 性能需求52.2.3 应用需求分析52.2.4其他需求分析53 系统的设计与实现63.1系统功能结构63.2各个功能分析63.2.1添加退货订单63.2.2退货订单73.2.3添加销售订单73.2.4汽车销售订单管理73.2.5查询库存信息84 数据库设计与实现94.1数据库概要结构设计94.2数据库逻辑结构设计95 系统界面设计
9、与实现115.1系统登陆界面设计115.2系统登陆后界面设计115.2.1汽车退货订单管理界面125.2.2汽车销售订单管理界面125.2.3汽车库存管理界面135.2.4汽车退货记录管理界面135.2.5汽车销售记录管理界面146 主要代码156.1配置文件156.2部分功能代码156.2.1 action代码(主要,逻辑结构)156.2.2 Dao代码(部分)17总结18致谢19参考文献201 概述1.1开发背景最近几年,中国的汽车行业发展迅猛,市场不断扩大,产生的销售信息量也越来越庞大,如何管理这些销售信息成为了许多汽车销售企业面临的一大难题,传统的汽车销售信息管理是采用纸质单据记录信息
10、,然后是销售人员手工管理这些单据,这就增加了销售人员的工作量和工作压力,并且工作效率低,数据可靠性差,而且进行数据分析和统计的难度非常大1。这些问题的出现在不同程度上制约了汽车行业的发展空间和发展速度,因此,在科技高速发展的现代,使用软件来进行信息管理相当必要,采用这种先进的管理方式可以大大增加汽车销售企业的市场竞争力。目前,中国的汽车行业已经进入国际市场,而国际市场的竞争更是激烈,我国的汽车产业同发达国家的相比还有很大的差距,最基本的差距是管理技术上的差距,尤其是汽车销售信息的管理与国外的管理方式差距甚远,不能在短时间内对销售数据进行详细的分析,从而不能及时得出汽车市场销售的规律,从而错过销
11、售时机,这样就可能大大降低了汽车的销量,从而使企业销售额降低,致使企业发展缓慢,跟不上国际市场发展潮流而逐渐被淘汰。汽车销售管理系统的销售管理模块,大大提高了企业管理的效率和准确性,使企业能够准确把握国际市场脉搏和发展动向,从而大大提高了企业的国际市场竞争力。该系统的开发将改善中国汽车企业的发展现状,提高中国汽车产业的发展空间和发展速度。1.2设计目的及内容1.2.1设计目的本模块设计的主要目的是实现管理员能够对销售订单和退货订单进行管理,以及能够查看车辆库存,从而进行销售。1.2.2设计内容本模块完成了管理员对于系统销售订单和退货订单的管理以及库存管理的功能。管理员可以对退货订单进行添加、删
12、除、修改、查询、查看的操作,同时对于销售订单也能进行添加、删除、修改、查询、查看的操作。库存管理功能实现退货订单入库,销售订单出库的功能,对汽车进行库存管理。1.3 技术概述1.3.1 B/S模式简介B/S(浏览器/服务器模式)是随着Internet结束的兴起,对C/S结构的一种改进2。在这个结构下,软件应用的业务逻辑完全在应用服务器端实现,用户表现完全在Web服务器实现,客户端直需要浏览器即可进行业务处理,是一种全新的软件系统构造技术。这种结构更成为当今应用软件的首选体系结构。1.3.2 JSP技术简介JSP(Java Server Page服务器网页)是从1998年开始出现的新技术。由Su
13、n公司倡导、许多公司参与一起建立的一种动态网页技术标准,是基于JavaServlet以及整个Java体系的web开发技术3。在传统的网页HTML文件(*.htm,*.html)中加入脚本片段和JSP标记(Tag),构成JSP网页(*.jsp)。JSP技术为创建显示动态生成内容的web页面提供了简便的方法。JSP作为Java家族的一员,承袭了Java的特点,即跨平台的特性,也即一次编译,到处运行。在国外,己经大量使用JSP作为网络应用程序的开发工具,而在国内,尽管JSP还不是主流开发技术,但是由于JSP的强大优势,许多网站都已经准备转向JSP,利用JSP来开发动态网站。 本系统使用通过使用jsp
14、对将后台处理过的数据进行格式化后给用户显示,是视图(view)核心部分。1.3.3 Mysql简介MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司。Mysql是最流行的关系型数据库管理系统,在WEB应用方面MySQL是最好的关系数据库管理系统应用软件之一。MySQL是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。MySQL所使用的SQL语言是用于访问数据库的最常用标准化语言。MySQL软件采用了双授权政策(本词条“授权政策”),它分为社区版和商业版,由于其体积小、速度快、
15、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择MySQL作为网站数据库。由于其社区版的性能卓越,搭配PHP和Apache可组成良好的开发环境。1.3.4 MVC模式简介MVC模式是Model-View-Controller的缩写,中文翻译为模式-视图-控制器4。MVC应用程序总是由这三个部分组成。Event(事件)导致Controller改变Model或View,或者同时改变两者。只要Controller改变了Models的数据或者属性,所有依赖的View都会自动更新。类似的,只要Controller改变了View,View会从潜在的Model中获取数据来刷新自己。MVC设
16、计思想:MVC英文即Model-View-Controller,即把一个应用的输入、处理、输出流程按照Model、View、Controller的方式进行分离,这样一个应用被分成三个层模型层、视图层、控制层5。MVC的优点:将视图展示和应用逻辑清晰的分离开来,降低了模型和视图之间的耦合性,使得系统设计时具有更高的灵活性。首先,最重要的是应该有多个视图对应一个模型的能力。在目前用户需求的快速变化下,可能有多种方式访问应用的要求。例如,订单模型可能有本系统的订单,也有网上订单,或者其他系统的订单,但对于订单的处理都是一样,也就是说订单的处理是一致的。按MVC设计模式,一个订单模型以及多个视图即可解
17、决问题。这样减少了代码的复制,即减少了代码的维护量,一旦模型发生改变,也易于维护。其次,由于模型返回的数据不带任何显示格式,因而这些模型也可直接应用于接口的使用6。1.4开发环境概述本项目开发工具及版本如下:Eclipse,jdk6.0,mysql5.6,Tomcat6.0,struts2,spring3.0,hibernate3.6 final,在window7系统平台进行项目的开发,调试,与运行。本系统用时下流行的javaweb开发框架SSH(Spring+Struts+Hibernate)进行开发,数据库采用轻巧稳定的MySql,界面使用jsp实现。本论文主要涉及软件,数据库与网络技术等
18、。涵盖知识面广,可有效地提高综合运用所学知识分析解决问题的能力,增强对事物的理解与掌握能力,掌握科学的研究方法,正确的设计思想,独立思考,勇于进取,探索创新,为今后进一步学习与工作奠定了良好的基础。1.5系统开发命名规则1.5.1命名规则(1)项目中命名规则项目中各个子项均以子项功能名称的英文组合,类名以对应的意思命名,组成的所有单词的首字母大写7;类中的方法依据功能而定,方法命名首单词的首字母小写,其他单词首字母均大写;项目中的页面命名是项目名为前缀加上相应功能名。(2)数据库命名规则数据库名称与项目名称相同,数据库中表命名规则是表名称英文意思的单词或多个单词的组合,单词首个字母大写;表中字
19、段名是相应字段的英文单词或多个单词的组合,单词首个字母大写。2 系统可行性研究和需求分析2.1可行性分析2.1.1 技术可行性技术可行性要考虑现有的技术条件是否能够顺利完成开发工作,软硬件配置是否满足开发的需求等。本系统用的是SSH框架开发,主打语言是JAVA,由于框架对一些复用的代码做了很好的封装,并且提供了友好的API,所以上手较快,开发效率也大大提高,采用流行的开发IDE: Eclipse,对开发调试都有很好的支持,当前的计算机硬件配置也完全能满足开发的需求,因此在技术上是绝对可行的。软件方面:由于目前单机模式相对发展成熟,故软件的开发平台成熟可行,它们速度快、容量大、可靠性能高、价格低
20、,完全能满足系统的需求。2.1.2 经济可行性开发该系统所需的相关资料可以通过已存在的相关系统进行调查采集,所需的其他应用软件、硬件系统也易于获得.因此,开发成本较低。而引进使用本系统后,与传统方式相比,具有高效率、低成本、高质量的特点,可以节省不少人力、物力及财力。所以,从经济的角度来看,该系统可行。2.1.3 运行可行性运行可行性是对组织结构的影响,现有人员和机构和环境对系统的适应性及人员培训补充计划的可行性8。当前信息化技术已经相当普及,各类操作人员水平都有相当的高度,所以在运行上是可行性的。2.1.4 法律可行性 所有技术资料都为合法。 开发过程中不存在知识产权问题。 未抄袭任何系统,
21、不存在侵犯版权问题。 开发过程中未涉及任何法律责任。2.2 需求分析需求分析是软件设计的一个重要的环节。本阶段对系统管理系统的应用情况作全面调查,以确定系统目标。确定用户的需求。用户对系统的需求我们从以下几方面进行分析。2.2.1 系统需求用JSP开发系统管理系统基于B/S模式9,系统软件和数据集中存放于服务器中,软件的安装与升级在服务器上进行。所有的工作基于浏览器,安装、使用、维护、升级十分简单。2.2.2 性能需求为了保证系统能够长期、安全、稳定、可靠、高效的运行。系统处理的准确性和及时性是系统的必要性能。由于本系统的添加功能对于整个系统的功能和性能完成举足轻重。作为系统的很多数据来源,其
22、准确性和及时性很大程度上决定了系统的成败。在系统开发过程中,必须采用一定的方法保证系统的准确性和及时性。2.2.3 应用需求分析(1)硬件要求CPU:Inter(R) Core(TM)2 Duo CPU 2.10GHzHDD:300GRAM:2.00GB(2)软件要求操作系统:Windows XP/Windows 7。数据库:Mysql数据库。浏览器:IE9.0。系统的性能要求通常指系统需要的存储容量以及后援存储,重新启动和安全性,运行效率等方面的考虑。 硬件系统环境:C600、1G MB(RAM)、500MB(HD)。系统运行时对数据的保密性要求不高对一般的数据不要求进行加密。此外,对其它软
23、件几乎没有依赖性,程序健壮性较好。2.2.4其他需求分析本系统有较好的可维护性、可靠性、可理解性、效率。易于用户理解和操作。可维护性包括了可读性、可修改性、可测试性、等含义10。可靠性通常包括正确性和健壮性。开发过程中,在各种矛盾的目标之间作权衡,并在一定的限制的条件下(经费、时间、可用的软、硬件资源等),使上述各方面最大限度的得到满足。3 系统的设计与实现3.1系统功能结构系统功能结构图,如下图3-1所示,系统功能结构图。汽车销售管理系统库存管理退货订单管理销售订单管理查询库存信息修改退货订单删除退货订单添加退货订单查询销售订单删除销售订单添加销售订单出库管理图 3 - 1系统功能结构图3.
24、2各个功能分析3.2.1添加退货订单填写退货信息,并提交,系统会将退回来的车辆进行入库操作。实现汽车的入库操作。如下图3-2 所示。需要管理员填写入库单,包括待入库产品的各项信息及入库单的各项信息。入库时,如果没有这种产品 ,可以选择直接在数据库中添加这项产品;如果存在则在原有数量的基础上增加待入库产品的数量。图 3 - 2添加退货订单主界面添加新产品该汽车存在增加产品数量添加退货订单汽车入库是否库存信息汽车库存信息3.2.2退货订单实现退货订单的查询、删除、修改操作,如图3-3 退货订单管理。查询退货订单主界面删除退货订单退货订单管理修改退货订单图 3 - 3退货订单管理3.2.3添加销售订
25、单实现添加销售订单的操作。如下图3-4 所示。管理员填写销售订单,包括待出库产品的各项信息及出库单的各项信息。出库时,如果没有这种产品,提示“没有找到相应的车辆或者仓库数量不足,请查明后重试!”;如果没有产品不存在或数量不足的情况则在原有数量的基础上减少待出库产品的数量。汽车出库汽车存在添加销售订单主界面否不能产生订单是数量不足否添加订单成功是图 3-4添加销售订单3.2.4汽车销售订单管理实现销售订单的查询、修改、删除操作。如下图3-5 所示。查询销售订单主界面删除销售订单销售订单管理修改销售订单图 3-5汽车销售订单管理3.2.5查询库存信息库存管理模块主要功能是查看库存信息,如下图3-6
26、 所示。主界面库存信息查询库存信息图 3-6 查看库存信息4 数据库设计与实现4.1数据库概要结构设计本系统数据库采用Mysql数据库,系统数据库名称为carslist。数据库中包含4张表。(1)管理员信息,包括的数据项有:管理员ID,账号、密码。(2)退货订单信息,包括的数据项有:销售订单ID、汽车名称、汽车型号、汽车价格、销售数量、汽车销售时间。(3)销售订单信息,包括的数据项有:退货订单ID、汽车名称、汽车型号、汽车价格、退货数量、退货时间。(4)库存信息,包括的数据项有:库存ID、更新日期、汽车名称、汽车型号、数量、单价。4.2数据库逻辑结构设计根据上述数据库的需求分析和概念结构设计,
27、设计了名称为carslist的数据库。数据库carslist由下面多个表格组成,各个表的命名及字段命名都是以相应名称的首字母组合而成,各个表格的设计结果如下表所示,每个表格表示在数据库中相对应的一个表。(1)管理员表,如:表4-1 所示。表 4 - 1管理员字段名称数据类型长度uidInt11unameVarchar255passwordVarchar255(2)退货订单表,如:表4-2 所示。表 4 - 2退货订单字段名称数据类型长度cidInt11cnameVarchar255ctypeVarchar255cpriceInt11cnumberInt11timeVarchar255(3)销售
28、订单表,如:表4-3 所示。表 4 - 3销售订单字段名称数据类型长度sidInt11snameVarchar255stypeVarchar255spriceInt11snumberInt11timeVarchar255(4)库存信息表,如:表4-4 所示。表 4 - 4库存信息字段名称数据类型长度cidInt11cnameVarchar255ctypeVarchar255cpriceInt11cnumberInt11timeVarchar2555 系统界面设计与实现5.1系统登陆界面设计登陆界面如下图5-1所示,登陆界面.输入管理员账号,密码登陆系统图 5 - 1 登陆界面5.2系统登陆后界
29、面设计登陆后界面如下图5-2所示,登陆后界面,左侧五个选项代表5个操作功能。图 5 - 2 登陆后界面5.2.1汽车退货订单管理界面填写退货信息点击提交,系统会把退货单储存在数据库里,如下图5-3所示。图 5 - 3 汽车退货订单界面5.2.2汽车销售订单管理界面填写销售订单信息,点击提交系统会将销售订单储存在数据库中,如下图5-4所示。图 5 - 4 汽车销售订单界面5.2.3汽车库存管理界面查看汽车库存信息如下图5-5所示。图 5 - 5 汽车库存管理界面5.2.4汽车退货记录管理界面能够根据汽车的名称和型号,查看汽车的退货情况,也能够进行修改,删除退货记录的操作,如下图5-6所示。图 5
30、 - 6 汽车退货记录管理界面5.2.5汽车销售记录管理界面能够根据汽车的名称和型号,查看汽车的销售情况,也能够进行修改,删除销售记录的操作,如下图5-7所示。图 5 - 7汽车销售记录管理界面6 主要代码6.1配置文件配置文件web.xml中主要用于配置struts2和spring的监听,该文件主要配置Struts项目些全局属性用户请求和响应Action之间对应关系及配置Action能用参数及处理结返回页面。另外,该文件配置了Spring的位置。login.htmlstruts2org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndE
31、xecuteFilterstruts2/*org.springframework.web.context.ContextLoaderListenercontextConfigLocationclasspath:applicationContext.xml6.2部分功能代码6.2.1 action代码(主要,逻辑结构)对数据进行预处理和些相关业务逻辑处理,实现页面之间的调度和跳转,把最终处理结果和要返回的对象放入session里面。public String findAll()List list = sdao.findAll();HttpServletRequest request =Servl
32、etActionContext.getRequest();request.getSession().setAttribute(list,list);returnfindAllok;public String delete()Selllist slist=new Selllist();slist.setSid(sid);sdao.delete(slist);List list = sdao.findAll();HttpServletRequest request =ServletActionContext.getRequest();request.getSession().setAttribut
33、e(list,list);returndelete;public String update()Selllist slist=new Selllist();slist.setSid(sid);slist.setSname(sname);slist.setSnumber(snumber);slist.setSprice(sprice);slist.setStype(stype);SimpleDateFormat df = new SimpleDateFormat(yyyy-MM-dd HH:mm:ss);/设置日期格式String date = df.format(new Date();Syst
34、em.out.println(df.format(new Date();/ new Date()为获取当前系统时间slist.setTime(date);sdao.update(slist);List list = sdao.findAll();HttpServletRequest request =ServletActionContext.getRequest();request.getSession().setAttribute(list,list);returnyes1;public String select()Selllist slist=new Selllist();if(snam
35、e != null& !.equals(sname)slist.setSname(sname);if(stype != null& !.equals(stype)slist.setStype(stype);List list=sdao.findByExample(slist);HttpServletRequest request =ServletActionContext.getRequest();request.getSession().setAttribute(list,list);returnyes1;public String login()Userinfo user=new User
36、info();user.setUname(uname);user.setPassword(password);List list = udao.findByExample(user);HttpServletRequest request =ServletActionContext.getRequest();request.getSession().setAttribute(tag, aaa);if(list.size()0)returnyes;returnno;6.2.2 Dao代码(部分)使用了Hibernate,它对JDBC进行了非常轻量级对象封装,使用对象编程思维来操纵数据库,主要用于对
37、数据库中的数据进行查询,删除,更新操作。Public void delete(InventoryNum persistentInstance) log.debug(deleting InventoryNum instance);try getHibernateTemplate().delete(persistentInstance);log.debug(delete successful); catch (RuntimeException re) log.error(delete failed, re);throw re;public Inventory findById(java.lang.
38、Integer id) log.debug(getting Inventory instance with id: + id);try Inventory instance = (Inventory) getHibernateTemplate().get(com.dao.Inventory, id);return instance; catch (RuntimeException re) log.error(get failed, re);throw re;Public List findByExample(Inventory instance) log.debug(finding Inven
39、tory instance by example);try List results = getHibernateTemplate().findByExample(instance);log.debug(find by example successful, result size: + results.size();return results; catch (RuntimeException re) log.error(find by example failed, re);throw re;Public List findAll() log.debug(finding all Inven
40、tory instances);try String queryString = from Inventory;return getHibernateTemplate().find(queryString); catch (RuntimeException re) log.error(find all failed, re);throw re;Public void update(Inventory instance)getHibernateTemplate().update(instance);总结在整个毕业论文设计的过程中我学到了做任何事情所要有的态度和心态,首先我明白了做学问要一丝不苟,
41、对于出现的任何问题和偏差都不要轻视,要通过正确的途径去解决,在做事情的过程中要有耐心和毅力,不要一遇到困难就打退堂鼓,只要坚持下去就可以找到思路去解决问题的。在工作中要学会与人合作的态度,认真听取别人的意见,这样做起事情来就可以事倍功半。通过这次毕业设计,我体会到了很多,首先要把大学这四年所学的东西全部学以致用,从开发环境的搭建,数据库的设计,项目业务的设计,以及前段UI的设计,的确是一个极大的挑战。但是在这个挑战中我学习到了很多,不会的就到图书管翻阅资料、或者去网上搜索,或者请教老师和同学,特别是老师和同学们,给予了我很大的帮助。在程序的设计中遇到了很多问题,这些问题都是需要毅力和决心去克服
42、和解决的,不能半途而废,只要积极的想办法,总能够找到解决问题的途径。毕业设计给我带来的不仅是知识的增长,更多的是自身能力和品质的提高,它教会我如何去发现问题,然后去解决问题;教会我不能轻言放弃,要坚持到底;这些品质不仅对于我的学习有帮助,对我将来的工作和生活更是有很大益处。致谢论文的顺利完成,首先我要感谢我的指导老师李阅历老师以及周围同学朋友的帮助,感谢他们提出宝贵的意见和建议。另外,要感谢在大学期间所有传授我知识的老师,是你们的悉心教导使我有了良好的专业课知识,这也是论文得以完成的基础。感谢四年来陪伴我的同学们,在我遇到问题时不厌其烦的给我讲解,让我整体有了进步。再次对以上所有的老师和同学表示由衷的感谢!参考文献1Allen Holub.If I were King: A propos