企业进销存管理系统论文

上传人:痛*** 文档编号:129068693 上传时间:2022-08-02 格式:DOC 页数:38 大小:1.57MB
收藏 版权申诉 举报 下载
企业进销存管理系统论文_第1页
第1页 / 共38页
企业进销存管理系统论文_第2页
第2页 / 共38页
企业进销存管理系统论文_第3页
第3页 / 共38页
资源描述:

《企业进销存管理系统论文》由会员分享,可在线阅读,更多相关《企业进销存管理系统论文(38页珍藏版)》请在装配图网上搜索。

1、企业进销存管理系统学 院专 业班 级学 号姓 名指导教师教师职称年月日 33 摘要【摘要】进销存管理系统是一个基于Internet的应用系统,它是一个面对当前的进销存管理工作基本还处于手工和半信息自动化处理状态而应运而生的一个基于Internet的一个完全信息自动化的系统,整个系统从符合操作简便、界面友好、灵活、实用、安全的要求出发,完成进货、销售、库存管理的全过程。企业单位只需具备访问Internet的条件即可在系统发布的站点上进行进销存的管理。在图型化的人机界面中完成日常的进销存管理工作.一方面摆脱了时间和空间的限制,另一方面有效的解决的数据共享的问题。经过实际使用证明,本文所设计的企业进

2、销存管理系统可以满足企业进货、销售管理方面的需要。【关键词】库存 销售 企业进销存管理系统目录摘要10 引言11 系统分析21.1 需求分析21.2 可行性分析22 总体设计22.1 项目规划22.2 系统功能结构图33 系统设计33.1 设计目标33.2 开发及运行环境43.3 数据库设计44 JavaBean的编写54.1 数据库操作的JavaBean的编写54.2 中文乱码处理的JavaBean的编写74.3 客户基本信息的JavaBean的编写74.4 提交客户信息的JavaBean的编写84.5 查询、分页JavaBean的编写(QuestString.java)94.6 显示系统时

3、间的JavaBean的编写145 用户登录模块设计156 系统首页设计167 基础信息管理主要功能模块设计187.1 客户信息管理设计187.2 客户信息查询设计198 库存管理主要功能模块设计228.1 商品入库信息设计238.2 商品价格调整设计26附录A 参考文献附录B 数据表附录C 文件架构图0 引言随着中国电子商务、互联网业务的迅猛发展,国内许多企业已跨入电脑网络管理时代,并因此提高了管理效率和市场竞争力。但目前仍有部分企业还停留在原始计账管理阶段。而随着全球经济信息化的进程和WTO的成功实现,企业面临着前所未有的机遇和挑战,在如此激变的社会形势和激烈的市场竞争下,愈来愈多的企业管理

4、者意识到效率管理和科学管理的重要性,以及增强市场竞争力的迫切性,因此建立科学、规范、高效的管理制度和秉承富有竞争力的经营理念是每一个企业管理者的渴望,企业采用电脑管理进货、库存、销售等诸多环节也已成为趋势及必然。在进货、库存、销售环节中,由于商品种类繁多、业务量大、库存管理复杂,使用手工操作的工作量很大,在操作过程中也很容易出现各种错误。而采用计算机管理则可以大大提高日常工作的效率,不仅将原来由手工操作的进货、出货及销售这一整套流程用计算机进行全程管理,而且消除了手工操作中可能存在的不确定因素,达到进销存管理流程清晰,从而能够比较彻底地贯彻经营者的管理模式。1 系统分析1.1 需求分析通过调查

5、研究,要求系统满足以下功能:q 由于操作人员的计算机知识水平有限,因此要求系统具有良好的人机界面。q 如果系统的使用对象较多,则要求有较好的权限管理。q 方便的数据查询功能,并支持多条件查询。q 在各种单据中根据输入的基础数据自动计算金额,尽量减少人工干预。q 对客户或供应商的往来账目进行有效管理,绝不存在假账、漏账、差账等情况。q 通过计算机,能够直接“透视”仓库存储情况。q 对某一时间段内的某种商品的销售情况按数量或金额进行升序或降序排行。q 图表分析年销售额。1.2 可行性分析通过计算机网络系统对企业进行全面的管理,满足了企业的现代化管理的要求。q 经济性当前许多中小型企业都使用人工管理

6、方式(即纸和笔)来管理企业的进销存,这样的管理方式既困难又浪费时间和成本,并且容易出现漏账、差账的情况,因此中小企业应该向大型企业那样采用先进的管理方式,提高企业效率、降低企业运营成本。q 技术性企业进销存管理系统从中小企业的实际出发,可有效地管理企业的进销存情况,并降低企业运营成本、及时调整营销策略、提高库房的利用率。2 总体设计2.1 项目规划企业进销存管理系统是一个典型的数据库开发应用程序,由基础信息管理、库存管理、商品销售、查询统计、往来管理、系统设置6部分组成。q 基础信息管理该模块主要是对企业的客户信息、商品信息、供应商信息进行有效管理,并可实现按不同条件对这些数据进行查询。q 库

7、存管理该模块主要是对商品的入库及入库退货信息进行有效管理,对商品的价格进行调整,同时可按不同条件查询库存商品。q 商品销售该模块主要是对商品的销售及销售退货信息进行有效管理。q 查询统计该模块主要实现按不同条件查询商品的入库信息及销售信息,并可对某一时间段内某种商品的销售情况按数量或金额进行升序或降序排行,同时可对某一年度的销售额进行图表分析。q 往来管理该模块主要实现对商品的入库结账、入库退货结账、销售结账、销售退货结账信息进行有效管理,同时可实现销售结账信息及入库结账信息的查询操作。q 系统设置访模块主要实现对操作员及操作员密码进行有效管理。2.2 系统功能结构图企业进销存管理系统的功能结

8、构如图1所示。图1 系统功能结构图3 系统设计3.1 设计目标本系统针对中小型企业进销存管理现状,通过网络对企业的进销存进行有效管理。本系统主要实现如下目标:q 系统采用人机对话方式,界面美观友好,信息查询灵活、方便、快捷、准确,数据存储安全可靠。q 实现企业内一些基础信息的设置及查询。q 商品的入库、入库退货、销售、销售退货流程清晰。q 数据计算自动完成,提高工作效率。q 与供应商和客户之间的账目清晰。q 以图表形式对年销售额进行分析。q 实现多条件查询。q 可方便快捷地查询库存信息,并可对商品价格进行调整。q 对某一时间段内的某种商品按照销售数量或销售金额进行销售升序排行或降序排行。q 操

9、作员可以随时修改自己的口令。q 对用户输入的数据,系统进行严格的数据检验,尽可能排除人为的错误。q 系统最大限度地实现了易维护性和易操作性。q 系统运行稳定、安全可靠。3.2 开发及运行环境硬件平台:q CPU:P41.8GHz。q 内存:256MB以上。软件平台:q 操作系统:Windows 2000。q 数据库:SQL Server 2000。q 开发工具包:JDK Version1.4.2。q JSP服务器:Tomcat。q 浏览器:IE5.0,推荐使用IE6.0。q 分辨率:最佳效果1024768像素。3.3 数据库设计本系统采用SQL Server 2000数据库,系统数据库名称为d

10、b_shopping。数据库db_shopping中包含17张表。关于数据库中的数据表请参见附录B。4 JavaBean的编写根据系统的需求编写需要的JavaBean。下面将给出企业进销存管理系统中所需要的JavaBean的编写过程。4.1 数据库操作的JavaBean的编写数据库连接的JavaBean的编写代码如下:package com.mingri.dbconn;import java.sql.*;import javax.naming.*;import javax.sql.DataSource;public class DBConn public static synchronized

11、 Connection getConnection() throws Exception try Context initCtx=new javax.naming.InitialContext(); /获得JNDI初始上下文对象/在JNDI命名空间java:comp/env段里获得上下文对象 Context envCtx=(Context)initCtx.lookup(java:comp/env); DataSource ds=(DataSource)envCtx.lookup(jdbc/mingri); /通过JNDI名获得数据源对象 return ds.getConnection(); c

12、atch(SQLException e) throw e; catch(NamingException e) throw e; 数据库操作的JavaBean的编写代码如下:package com.mingri.dbconn;import java.sql.*;import com.mingri.dbconn.DBConn;public class DBResult private Connection con; public DBResult() this.con=DBConn.getConnection(); /* * 用于获得执行SQL语句的ResultSet对象 */ public Re

13、sultSet getResult(String sql) try Statement stmt=con.createStatement(); ResultSet rs=stmt.executeQuery(sql); return rs; catch(Exception e) return null; /* * 用于执行SQL语句没有返回值 */ public void doExecute(String sql) try Statement stmt=con.createStatement(); stmt.executeQuery(sql); catch(Exception e) /* * 用

14、于获得执行SQL语句的PreparedStatement(预处理)对象 */ public PreparedStatement getPreparedStatement(String sql) try PreparedStatement pstmt=con.prepareStatement(sql); return pstmt; catch(Exception e) return null; /* * 关闭连接 */ public void closeCon() try this.con.close(); catch(Exception e) e.printStackTrace(); 4.2

15、中文乱码处理的JavaBean的编写在JSP开发中,经常出现乱码问题,我们可以指定编码方式,以消除乱码。package com.mingri.chinese;import java.io.*;public class ToChinese public String trans(String chi) String result=null; byte temp; try temp=chi.getBytes(iso-8859-1); result=new String(temp); catch(UnsupportedEncodingException e) System.out.println(e

16、.toString(); return result; 4.3 客户基本信息的JavaBean的编写这段代码用来封装客户的基本信息,并对每个属性提供setXXX()和getXXX()方法,来对其进行操作。package com.mingri.info;public class KhinfoBean private String khname; /客户全称 private String khjc; /客户简称 private String address; /地址 private String postcode; /邮政编码 private String tel; /电话 private Str

17、ing fax; /传真 private String lxr; /联系人 private String lxrtel; /联系人电话 private String email; /电子邮箱 private String khyh; /开户银行 private String yhzh; /银行账号 public String getKhname() return khname; public void setKhname(String khname) this.khname = khname; /省略部分代码4.4 提交客户信息的JavaBean的编写在填写完客户基本信息后,就应该向数据库中执

18、行插入操作。这个类中有两个方法setKhinfo()和Regist()。其中setKhinfo(KhinfoBean khinfo)方法是用来设置该类中的属性khinfo,其值为参数传递来的KhinfoBean的对象。然后执行预处理语句,并通过预处理对象pstmt的setString()方法来设置准备要插入数据库的内容,最后通过execute()来执行插入的操作。具体代码如下:package com.mingri.info;import com.mingri.dbconn.DBResult;import java.sql.*;public class KhRegist private Khin

19、foBean khinfo; DBResult rst=new DBResult(); public void setKhinfo(KhinfoBean khinfo) this.khinfo=khinfo; public void regist() throws Exception String reg=insert into tb_customer values(?,?,?,?,?,?,?,?,?,?,?); try PreparedStatement pstmt=rst.getPreparedStatement(reg); /创建一个预处理语句,然后设置他们的参数 pstmt.setSt

20、ring(1,khinfo.getKhname(); pstmt.setString(2,khinfo.getKhjc(); pstmt.setString(3,khinfo.getAddress(); pstmt.setString(4,khinfo.getPostcode(); pstmt.setString(5,khinfo.getTel(); pstmt.setString(6,khinfo.getFax(); pstmt.setString(7,khinfo.getLxr(); pstmt.setString(8,khinfo.getLxrtel(); pstmt.setString

21、(9,khinfo.getEmail(); pstmt.setString(10,khinfo.getKhyh(); pstmt.setString(11,khinfo.getYhzh(); /执行更新操作 pstmt.executeUpdate(); catch(Exception e) e.printStackTrace(); throw e; 4.5 查询、分页JavaBean的编写(QuestString.java)该系统中主要的方法分为两部分:一部分是根据用户提交的不同请求调用不用的方法来获取SQL语句;另一部分是用于分页显示。用于完成分页显示的方法有:q void setQuery

22、Sql(String httpfile,String pages,String strCount):通过参数传递来设置Bean中的属性。q void querySql(String countSql):执行SQL语句,获得分页显示时的各个属性。q String pageFooter():用来动态的给出一个表单该表单用来进行分页和统计页面间的跳转。这部分代码是本系统中查询部分的骨架,所有涉及到查询操作的代码部分全都调用了该Bean 中相应的方法,并完成了分页显示。代码如下:package com.mingri.info;import com.mingri.dbconn.DBResult;impo

23、rt java.sql.*;import java.io.*;public class QuestString private int curPage; /当前页数 private int maxPage; /最大页数 private int maxRowCount; /总记录数(即从数据库中查出的所有记录) private int pageSize=2; /每页要显示的记录数 private DBResult db; /记录集对象 private String httpFile; /当前地址栏的文件,即具体的JSP文件 private String cif; /选择的查询字段 private

24、 String ccif; /选择的查询运算符 private String qvalue; /查询关键字 private String countSql=null; /用来存储select count (*) 语句 private String topSql=null; /用来存储 select top 2语句 private String nowPage=null; /初始化当前页curPage变量,即获取当前页的具体页号 private String str_parameter; /在做翻页时,传递除pages以外的其他参数 private String andor; /查询的与/或条件

25、 private String sdate; /查询起始时间,即从什么日期开始查询 private String edate; /查询结束时间,即到什么日期结束 private String orderby; /排序条件,即按什么排序 private String paixu; /排序方法,即升序或降序 public QuestString() /构造方法,用来设置db为一个DBResult()对象 db=new DBResult(); public int getCurPage() return curPage; public void setCurPage(int curPage) thi

26、s.curPage = curPage; /省略了对Bean中其他属性设置的部分代码 /* * 通过参数传递来设置Bean中的属性 */ public void setQuerySql(String httpfile,String pages,String strCount) this.nowPage=pages; /将表单提交过来的参数pages(第几页)的值传递给变量nowPage保存 this.httpFile=httpfile; /用来动态设置处理表单请求的JSP文件 this.countSql=strCount; /用来设置执行select count(*)的SQL语句 try qu

27、erySql(countSql); /调用querySql方法,并将参数countSql传递到该方法中 catch(Exception e) e.printStackTrace(); /* * 执行SQL语句,获得分页显示时的各个属性 */ public void querySql(String countSql) throws SQLException /在setQuerySql方法中已经设置了nowPage的值,其值就是pages if(this.nowPage=null) /如果nowPage的值为空,也就是传递pages的值为空 this.curPage=1; /那么就将当前页的值设为

28、1; else this.curPage=Integer.parseInt(this.nowPage); if(this.curPagethis.maxPage) /如果当前页大于总页数,则当前页等于总页数 this.curPage=this.maxPage; /那么当前页就是最大页 rsCount.close(); /关闭总记录数的结果集 /* * 一个字符串,用来动态的给出一个表单 * 该表单用来进行分页和统计页面间的跳转 */ public String pageFooter() /创建一个表单 String str = ; int prev = this.curPage- 1; /向前

29、翻页,即当前页减1 int next = this.curPage +1; /向后翻页,即当前页加1 str = str + 总计 + this.getMaxRowCount() + 条记录, + 【共 + this.getMaxPage()+ 页】; str = str + 【 + this.pageSize + 条/页】 当前第 + this.getCurPage() + 页   ; if(this.curPage 1) str = str + 首页 ; else str = str + 首页 ; if(this.curPage 1) str = str + 上一页 ; else

30、 str = str + 上一页 ; if(this.curPage this.maxPage) str = str + 下一页 ; else str = str + 下一页 ; if(this.maxPage 1 & this.curPage!= this.maxPage) str = str + 尾页; else str = str + 尾页; /在页面跳转间设置隐藏表单,来保存不同的请求 str = str + 转到页+ ; return str; /* * 根据不同条件来获取不同的查询前N条的SQL语句 */ public String getString(String table)

31、if(ccif.equals(=) String strSql=select top +this.pageSize*this.curPage+ * from +table+ where+ +cif+=+qvalue+; return strSql; else if(ccif.equals(LIKE) String strSql=select top +this.pageSize*this.curPage+ * from +table+ where+ +cif+ +like+ +%+qvalue+%; return strSql; else if(ccif.equals(ALL) String

32、strSql=select top +this.pageSize*this.curPage+ * from +table; return strSql; else if(ccif.equals() String strSql=select top +this.pageSize*this.curPage+ * from +table+ where +cif+ +qvalue+; return strSql; return null; /* * 根据不同条件来获得不同的计算记录总数的SQL语句 */ public String getCount(String table) if(ccif.equa

33、ls(=) String strSql=select count(*) from +table+ where+ +cif+=+qvalue+; return strSql; else if(ccif.equals(LIKE) String strSql=select count(*) from +table+ where+ +cif+ +like+ +%+qvalue+%; return strSql; else if(ccif.equals(ALL) String strSql=select count(*) from +table; return strSql; else if(ccif.

34、equals() String strSql=select count(*) from +table+ where +cif+ +qvalue+; return strSql; return null; /* * 根据不同条件和不同的起始日期和结束日期来获得不同的计算记录总数的SQL语句 */ public String getDateCount(String table) if(ccif.equals(=) /在sdate到edate时间段中进行精确查询 String strSql=select count(*) from +table+ where +cif+ = +qvalue+ and

35、or+ xsdate between +sdate+ and +edate+; return strSql; else if(ccif.equals(LIKE) /在sdate到edate时间段中进行模糊查询 String strSql=select count(*) from +table+ where +cif+ like %+qvalue+%+ andor+ xsdate between +sdate+ and +edate+; return strSql; else if(ccif.equals(ALL) /取出表中所有记录 String strSql=select count(*)

36、from +table; return strSql; return null; /* * 根据不同条件和不同的起始日期和结束日期来获得不同的查询,前N条的SQL语句 */ public String getDateString(String table) if(ccif.equals(=) String strSql=select top +this.pageSize*this.curPage+ * from +table+ where +cif+ = +qvalue+andor+ xsdate between +sdate+ and +edate+; return strSql; else

37、 if(ccif.equals(LIKE) String strSql=select top +this.pageSize*this.curPage+ * from +table+ where +cif+ like %+qvalue+%+andor+ xsdate between +sdate+ and +edate+; return strSql; else if(ccif.equals(ALL) String strSql=select top +this.pageSize*this.curPage+ * from +table; return strSql; return null; /

38、* * 子查询中得到从起始日期到结束日期这段时间所有不重复的spid(商品id),并返回不重复的spid的总数 */ public String getOrderCount(String table) String strSql=select count(*) from (select spid from +table+ where xsdate between +sdate+ and +edate+ group by spid) as aa; return strSql; /* * 联合查询查询出某一表中从起始到结束日期间所有不重复的spid(商品id) * 并且将所有相同spid下的sl(

39、数量)和je(金额)求和,即计算出某一商品在 * 某一时间段内的总销售数量和销售总额 * 最后通过联合查询在tb_brand表(商品信息表)中将该spid所对应商品的其他一些信息查询出来 */ public String getOrderString(String table) String strSql=select top + this.pageSize*this.curPage+ * from tb_brand a inner join (select spid,sum(sl) as sl,sum(je) as je+ from +table+ where xsdate between

40、+sdate+ and +edate+ group by spid ) as b+ on a.id=b.spid order by +orderby+ +paixu; return strSql; 4.6 显示系统时间的JavaBean的编写在本系统中,商品的入库编号、销售票号等都是由“2位英文字母+系统时间+5位数字”自动生成的,所以我们将系统时间封装到Bean中,这样可以很好的将这部分代码重用。具体代码如下:package com.mingri.showtime;import java.util.*;public class ShowTime private Date date=null;

41、 private int yy; /保存由Date类中getYear()方法返回的整型数值 private int mm; /保存由Date类中getMonth()方法返回的整型数值 private int dd; /保存由Date类中getDate()方法返回的整型数值 private String sy; private String sm; private String sd; public ShowTime() date=new Date(); yy=date.getYear()+1900; /只有加上1900才是系统当前的年份 mm=date.getMonth()+1; /只有加上1

42、才识系统当前的月份 dd=date.getDate(); sy=String.valueOf(yy); /将整型yy转化为字符串类型 sm=String.valueOf(mm); /将整型mm转化为字符串类型 sd=String.valueOf(dd); /将整型dd转化为字符串类型 /如果月份是1位数在前面加上0,即如果是1月份那么显示的就是01if(sm.length()=1) sm=0+sm; if(sd.length()=1) sd=0+sd; public String getDateString() return sy+sm+sd; public String getDate()

43、return sy+-+sm+-+sd; 5 用户登录模块设计用户通过登录页面,进入企业进销存管理系统首页。该模块主要用于验证用户的身份及密码,其运行结果如图3所示。图3 用户登录页面的运行结果在登录页面中利用JavaScript脚本语言编写检测用户输入信息是否合法的函数,并通过单击【登录】按钮调用该函数,判断用户名或密码是否为空,如果为空,系统将给予提示。当用户输入合法信息后,提交该表单。用户登录页面中涉及的HTML表单元素如表1所示。表1 用户登录页面涉及的HTML表单元素名称类型含义重要属性form1form表单action=login.asp method=postusernamete

44、xt用户名passwordpassword密码submitbutton【登录】按钮onClick=check()resetreset【取消】按钮class=btn_grey value=取消用户登录页面中验证用户输入合法性的主要JavaScript代码如下:/省略部分代码 function check() if(form1.username.value=0) alert(请输入用户名);form1.username.focus();return; if(form1.password.value=0) alert(请输入密码);form1.password.focus();return; for

45、m1.submit(); 当用户输入合法信息后,就由表单属性action所指定的JSP文件来对这些信息进行验证。当验证通过后,进入到系统的主页面进行操作;否则给予信息提示,并返回到登录页面重新登录。关键代码如下:% request.setCharacterEncoding(gb2312); /对请求进行统一编码,能正常接受到中文 String username=request.getParameter(username); /接收表单中的username属性 String password=request.getParameter(password); /接收表单中的password属性 St

46、ring str=select * from tb_user where + username=+username+ and password=+password+; ResultSet rs=rst.getResult(str); /执行SQL语句获得结果集对象 /判断用户是否登录,当isLog的属性为0时,说明用户并没有登录 session.setAttribute(isLog,new String(0); if(!rs.next() /结果集没有找到所要查找的行 out.println(alert(用户名或密码错误);+ parent.location.href=login.html;)

47、; else session.setAttribute(username,rs.getString(username); /保存登录信息到session对象中 session.setAttribute(password,rs.getString(password); session.setAttribute(isLog,new String(1); /将isLog属性设置为1 rst.getResult(strUpdate); /执行SQL语句 response.sendRedirect(chat.jsp); /登录成功后转到系统主页面 %6 系统首页设计为了能够在同一页面中管理多个页,本系统首页的设计采用了框架技术将整个首页分成以下3部分。q 页面显示区(top.jsp):主要用于显示网站的旗帜广告条。q 页面导航区(left.jsp):主要用于管理功能导航。q 页面操作区(main.jsp):主要用于完成各种管理功能。首页设计的完整代码如下:企业进销存框架frameset rows=17

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!