基于JavaEE的仓库管理系统设计论文10030
《基于JavaEE的仓库管理系统设计论文10030》由会员分享,可在线阅读,更多相关《基于JavaEE的仓库管理系统设计论文10030(45页珍藏版)》请在装配图网上搜索。
1、毕业设计(论文)题 目: 基于Java EE的仓库管理系统 论 文 摘 要2随着经济的不断繁荣以及加入WTO后市场环境的变化,对企业的生产经营提出了更高的要求,企业必须综合利用各种先进制造技术,在网络与信息技术的支持下,改进现在的生产经营模式和组织结构,才能在市场竞争中赢得更多的份额。随着企业规模的扩大,仓库管理系统将发挥越来越重要的作用。高效方便的仓库管理系统,可以为生产经营提供坚强的后盾和有力的支持。仓库管理系统主要提供一个仓库业务及其作业管理的信息存储和检索系统。通过入库管理、出库管理、报表生成管理、仓库人员管理、仓库位置信息管理等功能模块来实现仓库的综合管理。本论文以标准的仓库管理模式
2、为蓝本,基于Java EE开发出一个可以用于一般单位的仓库管理系统,实现了仓库管理的高效性与安全性。本系统可以方便快捷地实现库管理中的货物登记、出库入库、库房管理等操作,使企业的仓库管理井井有条,为企业的健康发展创造良好的条件。关键词:仓库管理系统,Java EE,模块化设计,软件工程AbstractWith the continuous economic prosperity and accession to the WTO after the market environment changes, the production and operation of enterprises ha
3、ve set higher requirements, enterprises must comprehensive utilization of advanced manufacturing technology, the Internet and information technology, improving the existing production Business model and organizational structure, in order to win more market competition in the share. With the expansio
4、n of business scale, warehouse management system will play an increasingly important role. Facilitate the efficient warehouse management system, can provide a strong production and management backing and strong support. Warehouse management system to provide a major warehouse operations and its oper
5、ations management information storage and retrieval system. Through storage management, to the management, report generation management, storage management, storage location information management module to achieve integrated management of the warehouse. This paper to the warehouse management standa
6、rds based on the model, based on the Java EE can be used to develop a unit of General warehouse management system, warehouse management to achieve the efficiency and security. This system can quickly and easily achieve the management of goods registered to the stock and the treasury management opera
7、tion, the enterprise storage management orderly, for the healthy development of enterprises to create good conditions.Key Words:Warehouse management system, Java EE, modular design, software engineering目 录论文摘要目录一、引言 1.1 仓库管理系统的背景与意义 1.2 Java EE简介 1.3 本文的主要工作 二、相关技术介绍 2.1 Java EE相头原理及技术简介 2.1.1 Servl
8、et 2.1.2 JSP简介 2.1.3 EJB 2.2 Struts 2.2.1 STRUTS 的由来和发展 2.2.2 MVC简介 2.2.3 Struts 优缺点 2.2.4 Struts 的工程流程 2.3 Hibernate 三、系统分析与设计 3.1 引言 3.2 系统分析 3.2.1 系统可行性研究 3.2.2 系统使用环境 3.2.3 系统需求分析 1.系统功能概述 2.货物入库和出库的管理 3.出库入库记录的查询及报表 4.货物信息的管理 5.其它信息的管理 3.3 系统功能设计 四、数据库设计 4.1 引言 4.2 E-R图 4.3 数据表 五、系统界面与功能实现 5.1
9、页面流程图 5.2 创建系统登陆模块 5.2.1 系统登陆模块的功能 5.2.2 设计登陆窗口 5.3 创建主窗口模块 5.3.1 主窗口模块的功能 5.3.2 主窗口的设计5.4 仓库人员管理模块 5.4.1 仓库人员管理模块的功能 5.5 入库模块的实现 5.5.1 入库模块的功能 5.6 出库模块的实现 5.6.1 出库模块的功能 5.7 移库模块的实现 5.7.1 移库模块的功能 5.8 盘点模块的实现 5.8.1 盘点模块的功能 5.9 仓库设置模块的实现 5.9.1 仓库设置模块的功能 5.10 计量单位设置模块的实现 5.10.1 计量单位设置模块的功能 5.11 部门信息设置模
10、块的实现 5.11.1 部门信息设置模块的功能 5.12 操作类型设置模块的实现 5.12.1 操作类型设置模块的功能 5.13 期初设置模块的实现 5.13.1 期初设置模块的功能 5.14 货物存储信息查询模块的实现 5.14.1 货物存储信息查询模块的功能与布局 5.15 帮助模块的实现 5.15.1 帮助模块的功能与布局 六、Hibernate设计61Hibernate 简介62 Hibernate 生成 6.2.1连接数据库63 Hibernate的映射文件和类的生成 6.3.1生成对应的映射文件 6.3.2类及方法的生成七、总结参考文献一、引言1.1 仓库管理系统的背景与意义随着企
11、业规模的扩大,管理信息系统也发挥越来越重要的作用。作为企业管理信息系统关键组成部分的仓库管理系统的应用给企业带来巨大的效益。采用仓库管理系统将使企业改变其传统的手工记录模式,应用数据库技术使海量数据的存储与处理成为很方便的事情,这样可大幅缩短主要业务流程的处理时间,提高对市场的响应能力。 “物流服务最初起源于军事上的运用”, “物流”这一概念起源于二战期间的美国,英文称之为Logistics或者Physical Distribution,前者的使用率更高一些。物流一词最早被描述为泛指军队运输、补给和屯驻,后来被广泛用来描述商品实体的物理性流通活动,成为流通经济学中的术语。 物流(Logisti
12、c)到目前还没有一个统一的定义,综合各种物流的定义可以得出,物流是有形物品从出发点到最终消费点的流动存储活动,具体包括运输、保管、包装、装卸、搬运、流通加工及信息处理,从职能上可以分为:供应物流、生成物流、销售物流、回收物流和废弃物流五个职能。从70年代开始,计算机技术开始应用到物流领域。随着物流市场和物流信息化的发展,物流软件市场也应运而生并迅速发展起来,国内外出现了一大批物流软件供应商和物流软件。“物流软件作为管理软件,较其它应用软件呈现先进性、高效性、可靠性和安全性等特点;较其它管理软件,如ERP(Enterprise Resource Planning),具有以下特点:实施风险小,实施
13、迅速;效益显著、见效快。根据物流软件结构分类,就目前物流软件所使用的应用范围来说,物流软件包括如下几个子系统:WMS(Warehouse Management System,仓库管理系统)、TMS(Transportation Management System,运输管理系统。OMS(Order Management System,定单管理系统)、SMS(Service Management System,服务管理系统)。其中,WMS主要提供了一整套仓库业务以及作业管理系统。通过仓库管理系统可以实现库位分配自动化和智能化;提高仓库作业效率和速度,提供准确的库存信息,并使之与实际库存变化同步。根
14、据中国物流与采购联合会统计,2001年,中国与物流相关的年总支出为19000亿元人民币,物流成本占GDP的比重为20%左右。我国企业的物流支出成本约占总成本的30%,而国外企业的物流支出成本仅为7%。物流成本的巨大差距,抵消了我国企业在原材料和人工上的成本优势,降低了我国企业的竞争力。国内的很多企业,由于信息的记录、收集、汇总、处理分析还处于比较低的水平,记录中信息分散、格式随意、应用单一,收集中不及时、不全面、不完善、保留不科学,汇总时口径不一、主题多元、结果不一,处理分析方法落后、效率低下、只有短期,难以支持趋势等。仓库管理系统是通过入库业务、出库业务、库存调拨、库存调整,结合批次管理、物
15、料对应、库存盘点、质检管理、实时库存管理等功能综合运用的管理系统,对库存业务的物流和成本管理全过程进行有效控制和跟踪,实现完善的企业仓库信息管理。仓库管理系统的投入,将使仓库的管理更加正规化,为产品的出入库管理部门和销售部门提供了方便,降低了仓库的损耗。企业可以对售出的产品进行跟踪服务,同时也免去了销售人员按以往惯例亲自前往用户处去核实货物情况的麻烦,提高了办事效率,节省了费用,而且还避免了不必要的业务纠纷,维护了企业长期与用户建立的良好信誉。1.2 Java EE简介企业级多层应用系统的开发一直面临着重大挑战。开发商和广大程序员一直在努力推动和殷切期待一个成熟的、标准的企业级应用平台来简化和
16、规范企业级应用系统的开发和部署。Java技术的出现,尤其是J2EE(Java2 Platform Enterprise Edition)平台的推出正是这种努力的结果,也使得企业级应用系统的开发由此变得更加快速和方便。需要指出的是,J2EE本身是一个标准,它为不同厂商创建平台产品提供了标准,使不同J2EE平台产品之间的交互成为可能。SUN及其合作方将J2EE 1.5改名为Java EE 5,但是其架构跟改名前的J2EE没有区别。只是通过增强一些技术使得我们更快、更容易、更简单地开发企业应用程序1.3本文的主要工作本论文以标准的仓库管理模式为蓝本,根据软件工程的理论,开发出基于Java EE的适用
17、于中小单的位仓库管理系统。论文首先研究了系统开发的可行性,然后进行了需求分析,并将需求分析以文档的形式反馈给用户,并和用户进行交流进一步确认需求,然后根据需求分析采用了结构化分析方法进行了系统分析设计,并进行了数据库的建模工作,根据模型构建了数据库。后台数据库采用MYSQL完成。基于开放的开发架构Java EE,实现了系统登录模块、主窗口模块、仓库人员管理模块、入库模块、出库模块、入库报表生成模块、出库报表生成模块等。最后对全文进行了总结,对今后的工作提出了展望。二、相关技术介绍2.1 Java EE相关原理及技术简介 Java EE规范定义了一个完善的应用组件技术框架,作为企业级应用系统基本
18、构造模块的组件就是建立在这个框架之上。从简单的Web应用到复杂的分布式企业级应用,几乎所有的业务应用,都可以在此技术框架基础上构造。本文中使用的组件技术主要有三种类型:JSP网页、servlet和Enterprise JavaBean。2.1.1 Servlet Servlet是一些用来扩展Web服务器功能的Web组件,它基于请求/响应机制。Servlet从客户端(例如Web浏览器)获得请求,然后,将响应结果返回客户端。Servlet的这种特点使它非常适合于Web应用。Servlet和EJB组件的区别在于EJB组件所提供的服务器端组件特性并不能全部适用于Servlet,Servlet更适合于处
19、理简单的请求/响应任务,而且它不需要应用服务器所提供的复杂服务的支持。2.1.2 JSP简介JSP(Java Server Pages)是由Sun Microsystems 公司倡导、许多公司参与一起建立的一种动态网页技术标准,JSP技术在Servlet技术基础上发展起来的,它正在飞速发展中,现已成为Java服务器编程的重要组成部分。它虽然还未成型,但是它必将和J2EE(Java 2 Enterprise Edition)一起发展。JSP是结合markup(HTML和XML)和Java代码来处理一种动态页面。每一页第一次被调用时,通过JSP引擎自动被编译成Servlet,然后被执行,以后每次调
20、用时,执行编译过的Servlet。JSP提供了多种方式访问Java class、Servlet、Applets和Web Server,因此,Web应用的功能可以分成多个明确定义公用接口的组件,通过JSP将它们结合在一起.2.1.3 EJBEJB(Enterprise JavaBeans)是J2EE平台的核心,也是J2EE得到业界广泛关注和支持的主要原因。我们知道,J2EE的一个主要目标就是简化企业级多层应用系统的开发,使得程序员将主要精力放在业务逻辑的开发上。EJB正是基于这种思想的服务器端技术,它本身也是一种规范,该规范定义了一个可重用的组件框架来实现分布式的、面向对象的业务逻辑。EJB的核
21、心思想是将业务逻辑与底层的系统逻辑分开,使开发者只需关心业务逻辑,而由EJB容器实现目录服务、事务处理、持久性、安全性等底层系统逻辑。根据功能不同,规范中定义了三种Enterprise JvavaBean:会话Bean(Session Bean)、实体Bean(Entity Bean)和消息驱动Bean(MessageDriven Bean)。会话Bean分为无状态和有状态两种。一般无状态的会话Bean模拟商业逻辑,比如计算价格等。有状态的会话Bean通常模拟一个客户会话,它会临时保存客户信息,根据客户要求调用其它Bean来存取数据。两种会话Bean都不保存状态信息或者数据,当客户断开连接或者
22、服务器关闭时,会话Bean也就随之消失。一个会话Bean的典型例子是网站上的购物车。实体Bean模拟业务数据,它表示一个数据存储,可以是状态信息或者数据库中的一条记录。实体Bean在客户断开连接或者服务器关闭后,仍有服务保证其数据得以保存。消息驱动Bean在行为上很象会话Bean。不同的就是仅在需要向这些Bean发送消息时才调用消息驱动Bean,比如在需要的时候发送用户确认信息等。2.2 Struts2.2.1 STRUTS的由来和发展Struts 框架工具是 Apache 基金会 Jakarta 项目中推出的一个子项目。 Struts 在英文中是支架、支撑的意思,这也体现出 Struts 在
23、开发 Web 应用程序过程所起到的重要作用, Struts 为 Web 应用提供了通用的框架,让开发人员可以把主要精力集中在如何解决实际业务问题上,与此同时 Struts 框架也允许开发人员根据实际需要进行扩展和定制,从而可以更好的适应用户的需求。采用 Struts 可以简化遵循 MVC 设计模式的 Web 应用的开发工作,很好地实现代码重用,使开发人员从一些繁琐的工作中解脱出来,快速开发能够充分发挥 JSP/Servlet 优点、并具有强可扩展性的 Web 应用。总之, Struts 的出现使得 Web 应用的开发过程大大简化,从而能够缩短开发周期、提高开发效率。 Struts 架构一经推出
24、,即受到 Java 开发群体的广泛重视,从 2004 年开始逐渐升温,并日渐成为 Java 创建 Web 应用开发的最流行的框架工具,在目前 Java Web 程序员的招聘要求中,几乎都提出了对 Struts 的要求,精通 Struts 架构已经成为 Java Web 程序员必备的技能。2.2.2 MVC简介模型-视图-控制器(MVC)是80年代Smalltalk-80出现的一种软件设计模式,现在已经被广泛的使用。 1、模型(Model) 模型是应用程序的主体部分。模型表示业务数据,或者业务逻辑.2、视图(View) 视图是应用程序中用户界面相关的部分,是用户看到并与之交互的界面。 3、控制器
25、(controller) 控制器工作就是根据用户的输入,控制用户界面数据显示和更新model对象状态。MVC 式的出现不仅实现了功能模块和显示模块的分离,同时它还提高了应用系统的可维护性、可扩展性、可移植性和组件的可复用性早期的程序中,如果不注意对数功能和显示的解耦合,常常会导致程序的复杂及难以维护。很多VB,Delphi等RAD程序都有这种问题。甚至现在的C#,Java有时候也会出现把业务逻辑写在显示模块中的现象管MVC设计模式很早就提出,但在Web项目的开发中引入MVC却是步履维艰。主要原因:一是在早期的Web项目的开发中,程序语言和HTML的分离一直难以实现。CGI程序以字符串输出的形式
26、动态地生成HTML内容。后来随着脚本语言的出现,前面的方式又被倒了过来,改成将脚本语言书写的程序嵌入在HTML内容中。这两种方式有一个相同的不足之处即它们总是无法将程序语言和HTML分离。二是脚本语言的功能相对较弱,缺乏支持MVC设计模式的一些必要的技术基础。直到基于J2EE的JSP Model 2问世时才得以改观。它用JSP技术实现视图的功能,用Servlet技术实现控制器的功能,用JavaBean技术实现模型的功能JSP Model 1 与 JSP Model 2图1-3-1 MVC组件模型的关系和功能图图1-3-2 JSP Model 1图1-3-3 JSP Model 2 SUN在JS
27、P出现早期制定了两种规范,称为Model1和Model2。虽然Model2在一定程度上实现了MVC,但是它的应用用并不尽如人意model2 容易使系统出现多个Controller,并且对页面导航的处理比较复杂,有些人觉得model2仍不够好,于是Craig R. McClanahan 2000年5月 提交了一个WEB framework给Java Community.这就是后来的Struts。2001年7月,Struts1.0,正式发布。该项目也成为了Apache Jakarta的子项目之一 Struts实质上就是在Model2的基础上实现的一个MVC架构。它只有一个中心控制器,他采用XML定
28、制转向的URL。采用Action来处理逻辑2.2.3 Struts 优缺点 优点:Struts跟Tomcat、Turbine等诸多Apache项目一样,是开源软件,这是它的一大优点。使开发者能更深入的了解其内部实现机制。 除此之外,Struts的优点主要集中体现在两个方面:Taglib和页面导航。Taglib是Struts的标记库,灵活动用,能大大提高开发效率。另外,就目前国内的JSP开发者而言,除了使用JSP自带的常用标记外,很少开发自己的标记,或许Struts是一个很好的起点。关于页面导航,我认为那将是今后的一个发展方向,事实上,这样做,使系统的脉络更加清晰。通过一个配置文件,即可把握整个
29、系统各部分之间的联系,这对于后期的维护有着莫大的好处。尤其是当另一批开发者接手这个项目时,这种优势体现得更加明显。 缺点: Taglib是Struts的一大优势,但对于初学者而言,却需要一个持续学习的过程,甚至还会打乱你网页编写的习惯,但是,当你习惯了它时,你会觉得它真的很棒。 Struts将MVC的Controller一分为三,在获得结构更加清晰的同时,也增加了系统的复杂度。 Struts从产生到现在还不到半年,但已逐步越来越多运用于商业软件。虽然它现在还有不少缺点,但它是一种非常优秀的J2EE MVC实现方式。2.2.4 Struts的工作流程下图是Struts的工作流程,所有的请求都提交
30、给ActionServlet来处理。图1-3-4 Struts 工作流程图ActionServlet是一个FrontController,它是一个标准的Servlet,它将request转发给RequestProcessor来处理, ActionMapping是ActionConfig的子类,实质上是对struts-config.xml的一个映射,从中可以取得所有的配置信息 RequestProcessor根据提交过来的url,如*.do,从ActionMapping 中得到相应的ActionForn和Action。然后将request的参数对应到ActionForm中,进行form验证。如果
31、验证通过则调用Action的execute()方法来执行Action,最终返回ActionFoward。 ActionFoward是对mapping中一个foward的包装,对应于一个url ActionForm使用了ViewHelper模式,是对HTML中form的一个封装。其中包含有validate方法,用于验证form数据的有效性。ActionForm是一个符合JavaBean规范的类,所有的属性都应满足get和set对应。对于一些复杂的系统,还可以采用DynaActionForm来构造动态的Form,即通过预制参数来生成Form。这样可以更灵活的扩展程序。 ActionErrors是对
32、错误信息的包装,一旦在执行action或者form.validate中出现异常,即可产生一个ActionError并最终加入到ActionErrors。在Form验证的过程中,如果有Error发生,则会将页面重新导向至输入页,并提示错误。 Action是用于执行业务逻辑的RequsestHandler。每个Action都只建立一个instance。Action不是线程安全的,所以不应该在Action中访问特定资源。一般来说,应改使用 Business Delegate 模式来对Business tier进行访问以解除耦合。 Struts提供了多种Action供选择使用。普通的Action只能通
33、过调用execute执行一项任务,而DispatchAction可以根据配置参数执行,而不是仅进入execute()函数,这样可以执行多种任务。如insert,update等。LookupDispatchAction可以根据提交表单按钮的名称来执行函数。2.3 Hibernate Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用,最具革命意义的是,Hib
34、ernate可以在应用EJB的J2EE架构中取代CMP,完成数据持久化的重任。Hibernate的核心接口一共有5个,分别为:Session、SessionFactory、Transaction、Query和Configuration。这5个核心接口在任何开发中都会用到。通过这些接口,不仅可以对持久化对象进行存取,还能够进行事务控制。 三、 系统分析与设计3.1引言在设计软件系统之前,首先必须确定用户究竟要求软件系统完成什么任务,所以分析阶段的基本任务是了解用户的需求,并将用户的需求用书面形式表达出来。这个阶段还不是确定系统怎样完成它的工作,而仅仅是确定系统必须完成哪些工作,也就是对目标系统提
35、出完整、准确、清晰、具体的要求。系统分析的结果是系统开发的基础,关系到工程的成败和软件产品的质量。在全面客观的系统分析的基础上,根据用户提出的系统功能进行相应的功能设计。3.2系统分析 3.2.1系统可行性研究1.技术可行性 根据客户提出的系统功能、性能及实现系统的各项约束条件,根据新系统目标来衡量所需的技术是否具备,本系统是一个数据库管理和查询的系统,现有的技术以较为成熟,硬件、软件的性能要求、环境条件等各项条件良好,估计利用现有技术条件应完全可以达到该系统的功能目标。同时考虑给予的开发期限也较为充裕,预计系统是可以在规定期限内完成开发。本系统基于Java EE架构,采用了较为成熟的开发模式
36、。前端用Struts1.2,业务逻辑采用EJB3.0 的无状态会话Bean,持久映像层采用hibernate 1.3模式,应用服务器使用了使用最广泛的BEA Weblogic Server。 2.经济可行性 估算新系统的成本效益分析,其中包括估计项目开发的成本,开发费用和今后的运行、维护费用,估计新系统将获得的效益,估算开发成本是否回高于项目预期的全部经费。并且,分析系统开发是否会对其它产品或利润带来一定影响。(1)支出:基础投资:硬件设备:PC机软件设备:WINDOWS 2000、BEA Weblogic Server 10其它一次性支出:软件设计和开发费用经常性支出:软件维护费用、软件使用
37、费用。 (2)效益: 系统的效益可以从经济效益和社会效益两方面考虑。对于仓库管理系统则应着重分析其社会效益。例如,系统投入运行后可以使仓库管理实现科学化、规范化。曾强了工作人员对仓库管理能力、提高了工作效率。 3.运行可行性 新系统的研制和开发是充分得考虑工作人员对仓库的易于管理,管理者方便查询设备信息效率。从而能完全满足使用者的要求。 4.法律可行性 新系统的研制和开发,将不会侵犯他人、集体和国家的利益,不会违反国家政策和法律。3.2.2系统使用环境本系统的使用的最低配置要求:硬件环境:服务器:CPU:2.4G或以上;内存:1G RAM或以上;硬盘:80G或以上;客户端:CPU:1G;内存:
38、64MB以上内存或更高;硬盘:20G或以上。软件开发环境:操作系统:WindowsXP or Windows2000 server;所用工具:MyEclipse 6.0,BEA Weblogic Server 10;数据库:MYSQL;软件运行环境:操作系统:WindowsXP or Windows2000server;应用服务器:BEA Weblogic Server 10;数据库:MYSQL。3.2.3系统需求分析1系统功能概述库存管理货物管理员工管理仓 库 管 理 系 统编码设置出库 操作移库 操作盘点信息录入入库操作期初设置计量单位设置部门设置操作类型设置仓库设置货物信息查询货物信息查
39、询货物信息录入删除用户查询用户添加用户基础数据2货物入库和出库的管理仓库是用来存放货物的,货物进入仓库要进行登记记录,货物从仓库出库也要进行登记记录,这是仓库管理的主要内容。货物进入仓库,从入库申请的人员向执行货物入库的仓库保管员提交货物开始。入库申请人向仓库管理员提交货物和入库申请单,入库申请单记录本次入库的货物名称、数量、提交货物的单位、执行提交货物的人员以及货物注意事项等信息。库管依据送货人员提供的入库申请单对待入库货物进行检查。若待入库货物与入库申请单信息一致,则允许入库;若不一致,则禁止入库,请提交货物的单位重新出具入库申请单。对允许入库的货物,执行库管要对货物的信息进行登记,这些信
40、息包括入库货物名称、入库数量、入库时间、送货入库人员的信息、执行货物入库的执行人。进行登记后,将货物存入仓库。货物存入仓库后,执行入库操作的库管给提出入库申请的入库人员开具入库单,入库流程结束。货物从仓库中出库,是从需求货物的出库单位出库人员向执行出库操作的库管提交出库申请开始的。首先,出库人员向库管提交出库申请单。出库申请记录申请出库的货物名称、申请出库的数量、申请出库的单位、执行出库申请的人员等信息。执行出库的库管首先对出库单的真伪进行检验。对有效的出库单,依据其要求出库的货物名称查找仓库库存货物的信息和此货物的库存数量。如果有此货物,并且其库存数量满足出库申请单的数量,则执行出库操作的库
41、管保存出库申请单并进行出库登记。在出库登记中,执行库管要记录出库货物的名称、出库数量、出库后剩余数量、出库时间、货物去向、出库的仓库、执行出库的库管名称等信息。进行出库登记后,将货物出库。出库结束后,执行库管给提出出库申请的出库人员开具出库单,出库流程结束。3出库入库记录的查询及报表仓库的管理人员要对仓库存储的货物信息、入库记录和出库记录等及时掌握,这样才能及时了解仓库的运行现状,才有可能会使仓库处在良好的运行状态。所以,一般仓库管理过程中要能提供仓库的入库、出库记录的查询功能,并且能够将出库、入库记录生成报表,供管理人员使用,所以,对入库、出库记录的查询并将这些信息生成报表是仓库管理系统的重
42、要功能之一。4货物信息的管理仓库要存放货物,关于这些货物本身的信息,对货物的正常存储是非常重要的,例如,哪些货物需要防潮,哪些货物需要轻搬轻放等,所以,对货物本身的信息的登记、管理是仓库管理的重要内容。5其他信息的管理除了以上提到的一些功能外,仓库管理系统还应该能对一些其他的信息进行管理。例如,对每个仓库来说,都有一些存储位置用来存放货物,仓库管理过程中包括对这些存储位置进行的管理;每个仓库都有一些仓库管理员,对这些仓库管理员的管理也是仓库管理系统的功能之一。3.3系统功能设计根据仓库管理系统的一般需求,设计了如下一些功能模块: 1.仓库管理人员的管理模块 此功能模块方便对人员的管理以及数据安
43、全性,如(新增员工)。 2. 货物信息管理模块 此模块提供了货物基础数据的录入、货物信息查询等功能,方便及时了解库存信息。3.入库功能模块入库功能是仓库管理系统的基本功能之一。入库功能主要是实现登记入库记录的功能。这些信息应包括入库单据信息、入库数量和入库时间信息、执行入库操作的操作员信息和货物存放仓库的信息等。入库登记功能产生货物的入库记录,为以后进行入库货物的查询和生成报表以及出库操作产生操作数据,供管理人员掌握仓库内存储的货物情况。4出库功能模块出库功能是仓库管理系统的基本功能之二。出库功能主要是实现登记出库货物信息的功能。这些出库记录包括出库申请单据信息、出库数量和出库时间信息、执行出
44、库操作的库管信息和货物剩余信息等。出库功能依据入库登记功能产生的入库记录产生货物的出库记录,将出库记录存入系统,为以后的出库记录查询以及掌握仓库货物存储情况作基础。 5.盘点功能模块 此模块通过定期对仓库信息做清点,有效的了解了货物的流通情况和仓库货物的损耗情况。方便对货物信息的管理。6.移库功能模块 此模块是针对货物在内部进行调动的详细记载,从而对库存信息达到更方便的管理。四、数据库设计4.1引言数据库是一种存储数据并对数据进行操作的工具。数据库的作用在于组织和表达信息,即数据库就是相关信息的集合。本章从E-R模型的分析设计为切入点,重点介绍了数据库的设计。根据仓库管理系统的功能,将其E-R
45、图转化为个数据库表,为系统的实现奠定了基础。4.2 ER图实体联系图1:实体联系图2:实体联系图3:实体联系图4:4.3 数据表 1.仓库表(WH)列名数据类型长度允许空默认值说明whIDchar4仓库编号Namevarchar20仓库名whPersonvarchar10负责人whAddrvarchar100仓库地址2.货物信息表 (GDMESS)列名数据类型长度允许空默认值说明goodsIDchar8货物编号goodsNamevarchar30货物名称shortNamevarchar20NULL货物简称goodsClassvarchar10货物种类goodsStdvarchar20货物规格型
46、号Pricedouble8货物单价Weightdouble8NULL单位重量Volumedouble8NULL单位体积unitIDchar8计量单位Vendorvarchar20默任供应商lowQuantityint8最低库存量highQuantityint8最高库存量safeQuantityint8安全库存whIDchar8仓库编号highPricedouble8最高进价lowPricedouble8最低售价Buildervarchar10建档人modiPersonvarchar10NULL更改人modiTimedatetime8NULL更改时间nowQuantityint8当前数量chec
47、kCycleint8盘点周期lastCleckTimedatetime8NULL上次盘点时间 3.货物存储表 GDST列名数据类型长度允许空默认值说明goodsIDchar8货物编号whIDcahr8仓库编号Quantityint8数量4. 操作类型表 OPST列名数据类型长度允许空默认值说明opeTypeIDchar8操作类型编码opeTypeNavarchar20操作类型名称5. 库存记录主表 MSTOCK列名数据类型长度允许空默认值说明Codechar8单据号opeTypeIDchar8操作类型vouchTypechar8单据类型whIDchar8仓库编号Departchar20所属部门
48、Clerkvarchar20NULL业务员Operatorvarchar20操作员opTimedatetime8时间Vendorvarchar20NULL供应商Customervarchar20NULL客户Summdouble10合计金额orderCodechar8NULL定货单号receiveCodechar8NULL收货单号invoiceCodechar8发票号dispatchCodechar8NULL发货单号Memovarchar100NULL备注6.库存记录明细表 STOCK列名数据类型长度允许空默认值说明Codechar8单据号goodsIDchar8货物编号Unitchar8计量单
49、位Pricedouble8货物单价Quantityint8货物数量7.盘点表 MCHECK列名数据类型长度允许空默认值说明CVCodechar8盘点单号CheckDatedatetime8盘点日期checkPersonvarchar20盘点人whIDchar8仓库编号Opprovervarchar20批准人Makervarchar20制单人8.盘点明细表 CHECKVOUCHS 列名数据类型长度允许空默认值说明CVCodechar8盘点单号goodsIDchar8货物编号bookQuantityint8帐面数量actQuantityint8实际数量checkDatedatetime8盘点日期a
50、djQuantityint8调整数量actualWastedouble8实际损耗率allowWastedouble8合理损耗率Reasonvarchar100NULL损耗原因9.计量单位表 UNIT列名数量类型长度允许空默认值说明unitIDchar8计量单位编号unitNamevarchar8计量单位名称10.部门表 DEPT列名数量类型长度允许空默认值说明deptCodechar8部门编号deptNamevarchar20部门名称Depacint8NULL总人数11.员工表 EMP列名数量类型长度允许空默认值说明empCodechar8员工号empNamevarchar20员工姓名empS
51、exchar2NULL性别Passwordvarchar20123密码empTelvarchar15联系方式Memovarchar100NULL备注12.移库表 MOVESTOCK列名数量类型长度允许空默认值说明autoidint8记录号goodesidvarchar20货物编号sourcechar20源仓库targetchar20目的仓库unitchar20计量单位quantityint8数量opDatedatetime8NULL移库时间operatorvarchar20NULL操作员五、 系统界面与功能实现此系统是基于JAVA EE的库存管理系统。它主要包括三大模块,基础数据、库存操作还有
52、帮助。基础数据用于设计一些基础项目,库存操作是对应的入库出库一类对库存所作的操作,帮助是对整个系统的简单介绍。此系统是以MyEclipse 6.0为平台,在Struts 1.2 框架上用JSP页面来实现的一个库存管理。5.1页面流程图 图(一) 图(二) 图(三)5.2创建系统登陆模块5.2.1 系统登陆模块的功能 用户通过此登陆模块,可登陆到系统的内部,从而进行所需的操作。同时,它能用来校验用户是否属于该部门,是即应有对应的工号跟密码,不是便不能登陆进入。5.2.2 设计登陆窗口userLogin.jsp : 实现用户登陆在struts-config.xml中新建此页面后,建form跟action,同时建立转向,便会在它的source里建对应的form跟forward以及action: 5.3创建主窗口模块5.3.1 主窗口模块的功能 主窗口模块,是一个容器式的窗体,它包容了系统的所有分模块,系统运行时,在里面操作。5.4仓库人员管理模块5.4.1 仓库人员管理模块的功能 此模块是用于管理此部门人员的,由增加用户
- 温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。