ImageVerifierCode 换一换
格式:DOCX , 页数:22 ,大小:28.67KB ,
资源ID:9954284      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/9954284.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(企业进销存管理系统实训报告.docx)为本站会员(b****8)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

企业进销存管理系统实训报告.docx

1、企业进销存管理系统实训报告企业进销存管理系统实训报告小组成员:成波、钟秀、马姝婷、邢亚可、龙浩一、系统分析(一)需求概述在目前食材配送过程中,食材的管理至关重要。这里对食材的管理包括进、销、存3个方面。可以建立一个进销存管理系统,对企业的管理者、营业员、库存管理员等减轻其工作量,便于经营管理。功能需求:基础信息管理功能模块:主要负责管理供应商信息、商品信息以及客户信息。进货管理功能模块:采购计划、采购订单、采购入库、采购退货、应付款、采购付款。销售管理功能模块:、报价单、销售订单、销售出库、销售退货、应收款、销售收款。查询统计功能模块:主要负责统计企业的客户查询、商品查询、供应商查询、销售查询

2、、销售退货查询、商品出入库情况以及销售排行查询。库存管理功能模块:其它入库、其它出库、库存警报、库存报表、基本资料设计。系统管理,主要负责管理用户信息和用户登录,以及初期建账。食材配送公司需要处理大量的库存信息,还要时刻更新产品的销售信息,不断添加商品信息。面对不同种类的信息,需要合理的数据库结构来保存数据信息,需要有效的程序结构支持各种数据操作的执行。它最主要的特点是能够实时的和准确的控制店内的销售情况。如果可以能够实时掌握销售流程及销售情况,则可以有效地加速商品的周转率并提高服务质量,而且可以减少产品售价不符等所产生的问题。顾客的消费要求的是希望能及时采购到所需的新鲜的食材,并且还要保证在

3、食材配送过程中提供优质、方便的服务。(二)系统概述本系统的开发适用于多个行业,可以帮助企业快速有效管理进货、销售、库存、查询统计等各项业务,合理控制进销存各个环节,提高资金利用率,实现管理高效率和实时性。本系统是根据人们在日常生活中的实际需求而开发的,完全能够实现人们对商品的基础信息管理、进货管理、销售管理、查询统计、库存管理、系统管理等功能,一般而言,通过使用进销存管理系统,可以在以下几方面提高企业的管理水平:1)更好地了解供应商和客户信息,加强对商品资料的管理。2)降低采购成本,及时了解采购情况。3)准确了解销售动态,及时调整营销策略。4)了解库存情况,及时进行价格管理以及库存数量维护。5

4、)减少储备资金占用,加速资金周转,提高资金利用率。6)提供商业数据智能分析,了解商业动态,为管理者提供决策依据。1系统功能分析系统功能结构图如下:(三)可行性分析1人员角度的可行性鉴于本组人员实力薄弱,无系统开发技术基础,我们决定根据老师提供的文件资料作为项目实施的参考依据,通过项目实训来锻炼我们的动手能力、实际操作能力。评价尺度:以能参照资料制作出完成的进销存管理系统为标准。2技术角度的可行性本系统采用Java Swing+SQL server 2005实现。使用集成开发工具MyEclipse 8.5进行开发。从前人的开发经验来看,小组采用的进销存管理系统应用软件的开发手段是完全可行的。二、

5、项目计划书(一)项目背景通过项目模拟实训来锻炼同学们的动手能力,为将来毕业求职实习、考研做准备。(二)项目目标1)界面简洁友好,操作简单。2)系统功能包括基础信息、进货管理、销售管理、库存管理、查询统计、系统管理6个部分。3)文档结构清晰,包括(项目需求分析、项目开发过程、项目技术说明、项目功能实现、项目测试结果等)4)小组成员都应参与到整个项目的实现过程中来,对每个环节都应该有所了解,掌握整个项目开发的每一个细节,成员之间要多沟通,工作上要协调配合好。(三)项目实现准备阶段1业务逻辑编码规则1)数据库名称统一为:db_JXC(进销存管理系统数据库)2)数据表统一tb开头,如:tb_sell_

6、main(销售主表),tb_sell_detail(销售明细表)。字段名(一律采用英文单词,不知道的在线翻译一下),如:ID(流水号),Name(名称),ProductInfo(商品信息)。3)tb_spinfo(商品信息表)。商品信息表主要是用来保存商品的名称、产地等基本信息。表结构如下图所示:4)tb_khinfo(客户信息表)。客户信息表主要保存客户的姓名、地址、联系方式等基本信息等。表结构如下图所示:5)tb_gysinfo(供应商信息表)。供应商信息表主要保存供应商的名称、地址等供应商的基本信息。表结构如下图所示:6)tb_kucun(库存管理表)。库存管理表中主要保存着每一件商品的

7、单价、在仓库中的存储数量、一共的金额等信息。表结构如下图所示:7)tb_ruku_main(入库主表)和tb_ruku_detail(入库明细表)。入库表中主要保存的是商品入库之后的基本信息如商品名称、产地、金额等信息。表结构职下图所示:8)tb_rkth_main(入库退货主表)和tb_ruku_detail(入库退货明细表)。入库退货表中主要保存的是入库之后的退货信息,信息内容基本与入库表相同。表结构如下图所示:9)tb_sell_main(销售主表)和tb_sell_detail(销售明细表)。销售表主要保存销售情况的信息,并且添加了销售日期等信息。表结构如下图所示:10)tb_xsth

8、_main(销售退货表)和tb_xsth_detail(销售退货明细表)。销售退货表主要是用来保存在销售出的商品产生退货情况的基本信息。表结构如下图所示:2业务编码规则1)供应商编号(如gys1000,gys1001)2)客户编号(如kh1000,kh1001,kh1002)3)商品编号(如sp2045,sp2046,sp2047)4)销售单编号(XS+日期+编号,如XS20150509001)5)入库编号(RK+日期+编号,如RK20150511003)6)入库退货编号(RT+日期+编号,如RT20150512004)3系统E-R图1)客户实体E-R图,包括客户编号、客户名称、简称、地址、电

9、话、邮政编码、联系人、联系人电话、传真、开户行和账号等属性。2)供应商E-R图,包括编号、名称、简称、地址、电话、邮政编码、传真、联系人、联系电话、开户行和E-mail等属性。3)商品实体E-R图,包括编号、商品名称、商品简称、产地、单位、规格、包装、生产日期、保质期、商品简介和供应商等属性。4)使用PowerDesigner建模进行数据库设计。具体请参照JAVA项目开发全程实录1.4.3章。并用SQL server 2005创建数据库。(四)项目实现开发阶段1人员分工1)龙浩:美工设计、主窗体设计、公共模块设计2)钟秀:进货管理模块设计、销售管理模块设计3)邢亚可:查询统计模块设计、库存管理

10、模块设计、系统数据库设4)马姝婷:项目进度安排、基础信息模块设计、系统功能设计5)成波:系统需求分析、系统项目说明书、系统测试2模块分工1)主窗体设计。代码参照JAVA项目开发全程实录1.5章。2)公共模块设计。代码参照JAVA项目开发全程实录1.6章。3)基础信息模块。代码参照JAVA项目开发全程实录1.7章。4)进货管理模块。代码参照JAVA项目开发全程实录1.8章。5)销售管理模块。无参考代码,自行开发。6)库存管理模块。代码参照JAVA项目开发全程实录1.10章。7)查询统计模块。代码参照JAVA项目开发全程实录1.9章。8)系统管理模块。无参照代码,自行开发。(五)项目测试1单元测试

11、每个模块开发时进行单元测试。2系统测试开发后进行系统测试,并编写系统测试报告。三、系统实施(一)开发环境准备安装SQL server 2005和myeclipse8.5。(二)创建数据库连接1软件安装和帐户设定1-1:安装“MS Sql Server 2005(SP2)”(内置帐户选择sa,密码设为123;如果没有设置内置帐户sa的话,请直接使用WinNT登录“SQL Server Management Studio”,选择安全性登录名sa登录属性,然后设置密码123,关闭“SQL Server Management Studio”)1-2:安装“MyEclipse 5.5.1 GA”1-3:

12、下载连接驱动包“sqljdbc.jar” 1-4:设置SQL Server服务器:a.“开始”“程序”“Microsoft SQL Server 2005”“配置工具”“SQL Server Configuration Manager”(确认“SQL Server Management Studio”已关闭)b.“SQL Server 2005服务”中停止服务“SQL Server(SQLEXPRESS)”(默认是启动状态)c.“SQL Server 2005网络配置”“MSSQLSERVER的协议”,启动“TCP/IP”(默认是禁用状态),然后双击“TCP/IP”进入属性设置,在“IP地址”

13、里,确认“IPAll”中的“TCP端口”为1433d.“SQL Server 2005服务”中启动服务“SQL Server(MSSQLSERVER)”(默认是停止状态)e.关闭“SQL Server Configuration Manager”(此时可以启动“SQL Server Management Studio”,并用帐户sa、密码123登录,SQL Server服务器设置正确的话应该能登录成功)2创建测试数据库和表2-1:启动“SQL Server Management Studio”,并用帐户sa、密码123登录(SQL Server服务器设置正确的话应该能登录成功),创建一个数据库

14、JSPTest,内建一个表regist2-2:创建测试的Java工程和代码 2-3:启动“MyEclipse”“File”“New”“Project”“Java Project”,命名为Test2-4:打开Test的“Properties”“Java Build Path”“Libraries”“Add External JARs”,选择下载好的连接驱动包“sqljdbc.jar”,然后点击“OK”确定 2-5:SQL Server 2005中加载驱动和URL的语句为:protected static String dbClassName=com.microsoft.sqlserver.jdb

15、c.SQLServerDriver;protected static String dbUrl=jdbc:sqlserver:/localhost:1433;DatabaseName=db_JXC;protected static String dbUser=sa;protected static String dbPwd=123;四、系统总体设计(一)主窗体设计主窗体是系统的欢迎界面。用程序的主窗体包括系统菜单和工具栏,其中系统菜单是包含系统中所有功能的菜单项,工具栏是提供常用的功能的快捷访问按钮。(该系统采用了导航面板综合了系统菜单和工具栏的优点,导航面板的界面更美观,操作更快捷。)1创建

16、主窗体1)创建JXCFrame类,在类中创建和初始化窗体对象,为窗体添加桌面面板,并且设置背景图片。Frame=new JFrame(“企业进销存管理系统”);/创建窗体对象desktopPanel=new JDeskPanel();/创建桌面面板JTabbedPane navigationPanel=createNavigationPanel();/创建导航面板2)编写updateBackImage()方法,初始化背景标签,背景标签使用HTML超文本语言设置了主窗体的背景图片(该图片会随着主窗体的大小自动缩放)。3)在类的静态代码中设置了系统的外观样式。使用了UIManager类的setLo

17、okAndFeel()方法设置程序界面使用本地外观。4)编写主窗体的mian()入口方法,创建登录窗体对象(登录窗体会验证登录信息,并显示主窗体界面)(二)创建导航面板1)在JXCFrame类中编写createNavigationPanel()方法,创建JTabbePanel选项卡面板对象。(为了突出选项卡的立体效果,设置该选项卡使用了BevelBorder边框效果。)然后依次创建了基础信息管理面板、库存管理面板、销售管理面板、查询统计面板、进货管理面板和系统管理面板的选项卡。JTabbedPane tabbedPane=new JTabbedPane();/创建JTabbePanel选项卡面

18、板对象JPanel baseManagePanel=new JPanel();/基础信息管理面板JPanel depotManagePanel=new JPanel();/库存管理面板JPanel sellManagePanel=new JPanel();/销售管理面板JPanel searchStatisticPanel=new JPanel();/查询统计面板JPanel stockManagePanel=new JPanel();/进货管理面板JPanel sysManagePanel=new JPanel();/管理系统面板2)编写createFrameButton()方法,该方法负责

19、创建Action对象,该对象是用来创建并显示窗体对象,(图标、文本等属性),本系统没有使用系统菜单,所以该方法直接创建按钮对象。Icon icon=new ImageIcon(imgUrl);/创建按钮图标Icon_roll=new ImageIcon(imgUrl_roll);/创建鼠标经过按钮的图标Icon_down=new ImageIcon(imgUrl_down);/创建按钮按下的图标Action action=new openFrameAction(fName,cname,icon);/用openFrameAction类创建Actio对象3)编写内部类openFrameAction

20、,它必须要继承AbstraAction类实现Action接口。该类用于创建导航按钮的Ation对象,并且为每一个导航按钮定义创建不同窗体对象的动作监听器,当这个监听器的按钮被按下时,调用getFrame()方法获取相应的窗体对象,并显示在主窗体中。4)编写getIFrame()方法。该方法就是用来创建指定名称的窗体对象,使用了java反射技术,调用不同窗体类的默认构造方法创建窗体对象。(三)公共模块设计1编写Dao公共类1)Dao类主要负责有关数据库的操作,该类在静态代码段中驱动并连接数据库,然后将所有的数据库访问方法定义为静态的。Class.forName(dbClassName).newI

21、nstance();/加载数据库驱动类conn=DriverManager.getConnection(dbUrl,dbUser,dbPwd);/获取数据库连接2)addGys()方法(添加供应商信息的方法)该方法用于添加供应商的基础信息,它接收供应商的实体类TbGysinfo作方法的参数,然后把实体对象中的所有属性存入供应商数据表中。3)getGysinfo()方法(读取指定供应商的信息)该方法将根据Item对象中封装的供应商ID编号和供应商名称获取供应商的数据,然后将该供应商的数据封装到实体对象中,然后返回该实体对象。4)updateGys()方法(修改供应商信息的方法)该方法用于更新供应

22、商的基础信息,它接收供应商的实体类TbGysinfo作方法参数,在方法中直接解析供应商实体对象中的属性,并且将这些属性更新到数据表中。5)insertRukuInfo()方法该方法负责完成入库单信息的添加,(库存表、入库主表、入库详细表等多个数据表的操作)。为了保证数据的完整性,该方法将入库信息的添加操作放在事务中完成,方法将接收入库主表的实体类TbRukuMain作为参数,该实体类中包含了入库详细表的引用。6)getKucun()方法该方法用于获取指定商品ID编号或者名称的库存信息,方法接收一个Item对象作参数,该对象中封装了商品的ID编号和商品的名称信息,如果库存表中存在该商品的库存记录

23、,就获取该记录并将记录中的数据封装到库存表的实体对象中,然后将该实体对象作为方法的返回值。2编写Item类Item类主要用于封装和传递参数信息,这是典型命令模式的实现。在Dao类中经常使用该类作为方法参数;在各个窗体界面中也经常使用该类作组件数据,其toString()方法将返回name属性值,所以显示到各个组件上的内容是Item类的对象所代表的商品、供应商、或者客户等信息的名称。(四)基础信息主要功能模块详细设计基础信息管理模块的有三个功能:客户信息管理、商品信息管理和供应商信息管理。其中客户信息管理所使用的的数据表是tb_khinfo,其功能类包括KeHuTianJiaPanel类和KeH

24、uXiuGaiPanel类;商品信息管理所使用的数据表是tb_spinfo,其功能类包括ShangPinTianJiaPanel类和ShangPinXiuGaiPanel类;供应商信息管理所使用的数据表是tb_gysinfo,其功能类包括GysTianJiaPanel类和GysXiuGaiPanel类。整个基础信息管理模块的技术分析以供应商信息管理面板为例,下面简单介绍一下供应商信息管理的添加、修改和删除的实现过程。1GysTianJiaPanel类该类用于实现系统供应商添加功能,实现在界面将显示多个用于输入供应商信息的文本框。界面中主要包括以下控件:控件类型控件名称主要属性用途JtextFi

25、eldquanChengF无供应商全称JianChengF无简称BianMaF无邮政编码DiZhiF无地址DianHuaF无电话ChuangZhenF无传真LianXiRenF无联系人lianXiRenDianHuaF无联系人电话YinHangF无银行EmailF无邮箱JbuttonTjButton设置按钮文本为“添加”设置动作监听器为TjActionListener类的实例对象添加ResetButton设置按钮文本为“重填”设置动作监听器为ResetActionListener类的实例对象重填要点介绍:1)ResetActionListener类。作为“重填”按钮的事件监听器。该类必须实现A

26、ctionListener接口,并在actionPerformed()方法中清除界面中的所有文本框内容。代码如下:2)TjActionListener类。作为“添加”按钮的事件监听器。该类必须实现ActionListener接口,并在actionPerformed()方法中实现用户输入的验证和供应商信息的保存。代码如下:2GysXiuGaiPanel类该类主要实现供应商修改和删除的功能。在该界面中有许多文本框用于输入供应商信息,这些文本框会根据所选供应商自动填充内容,点击修改按钮后回自动写入修改后的供应商内容。控件类型控件名称主要属性用途JtextFieldquanChengF无供应商全称Ji

27、anChengF无简称BianMaF无邮政编码DiZhiF无地址DianHuaF无电话ChuangZhenF无传真LianXiRenF无联系人lianXiRenDianHuaF无联系人电话YinHangF无银行EmailF无邮箱JComboBoxGys设置初始大小为(230,21)调用initComboBox()方法初始化下拉列表设置组件选择事件调用doGysSelectAction()方法选择供应商JbuttontjjButton设置按钮文本为“修改”设置动作监听器为ModifyActionListener类的实例对象修改resetButton设置按钮文本为“删除”设置动作监听器为DeltA

28、ctionListener类的实例对象删除要点介绍:1)initComboBox()方法。用于初始化选择供应商的下拉列表框。该方法先获取Dao类中的getGysInfos()方法,然后再将获取到的信息封装成Item对象并添加到下拉列表框中(主要是获取ID和供应商名称)。然后再下拉列表框的Item对象中用toString()方法显示供应商名称。代码:2)doGysSelectAction()方法。在使用下拉列表框时选择或更改供应商信息的时候被调用。主要根据选择的供应商名称,填充相应的供应商信息到文本框中。代码如下:3)ModifyActionListener类。修改按钮的事件监听器。必须实现Ac

29、tionListener接口,并在actionPerformed()方法中获取文本框内容,并可以将修改后的供应商信息,通过调用Dao类的updateGys()方法,把修改后的信息写入到数据库。代码:4)DeltActionListener类。删除按钮的事件监听器。必须实现ActionListener接口,并在actionPerformed()方法中获取文本框内容,通过调用Dao类中的delete()实现把供应商信息从后台数据库删除。代码:(五)进货管理模块设计企业进销存管理系统中的进货模块管理主要包括进货单和进货退货两个部分。由于它们的实现方法相似,这里主要以进货单功能为主,介绍进货模块对本系

30、统的意义和实现的业务逻辑。1进货单主要负责记录企业的商品进货信息,可以单击“添加”按钮,在商品表中添加进货的商品信息。在“供应商”下拉列表框中选择不同的供应商,将会改变商品中可以添加的商品。进货单的程序界面如下图:2进货退货进货退货功能主要负责记录进货管理中的退货信息,界面效果如下图。在选择了退货的商品之后,单价“退货”,将把表格中商品退货信息更新到数据库中。3技术分析进货管理模块使用JDBC实现事务操作,因为进货和退货的业务逻辑涉及到3个数据表,为保证数据的完整性,将3个数据表的操作放在事务中实现,如果对任何一个数据表的操作出现错误或是不可执行的操作,那么事务中的所有操作都将取消,并恢复到事

31、务执行的数据状态;否则3个数据表的操作全部执行。下面是JDBC事务操作的关键方法。1)setAutoCommit()方法该方法用于连接对象的自动提交模式。如果连接处对象的自动提交模式为true,则它的所有SQL语句被执行作为单个事务提交;否则,该连接对象的SQL语句将聚集到事务中,直到调用commit()方法或rollback()方法为止。默认情况下,新连接的自动提交模式为true。语句:Void setAutoCommit(boolean autoCommit)autoCommit:该参数为true表示启用连接对象的自动提交模式:false表示禁用链接对象的自动提交模式。getAutoCommit()判断此连接对象是否启用了自动提交模式。语法:Boolean getAutoCommit()2)com

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1