中小企业erp管理系统1毕业设计.doc
河北农业大学 本科毕业论文(设计)题 目: 中小商业企业ERP 学 院: 现代科技学院 专业班级: 计算机科学与技术0901 学 号: 2009614070102 学生姓名: 张轩 指导教师姓名: 杨学全 指导教师职称: 教授 二O一三 年 六 月 一 日摘 要在我们生活的21世纪里计算机技术已经在各行各业中发挥着不可替代的作用。当前越来越多的商业、企事业单位已经将计算机技术应用于日常的管理工作,以信息技术为主要标志的科技进步日新月异,高科技成果向现实生产力的转化越来越快。企业的物资供应管理往往是很复杂繁琐的,由于掌握的物资种类众多,订货,管理,发放的渠道各有差异,各个企业之间的管理体制不尽相同,各类统计计划报表繁多,因此物资管理必须实现计算机化,而且必须根据企业的具体情况制定便提高工作效率。传统的依靠管理人员人工传递信息和数据的管理方式就无法满足企业日益增长的业务需求了。根据当前存在的问题,联系实际情况设计实现了一个具有部分ERP(Enterprise Resource Planning)功能的管理网站,尽力做到降低实施成本,减少实施风险,加快实施进度,增加投资回报。这是一个基于WEB页面的、B/S(Browser/Server)模式的管理系统。本系统采用的是编程工具Visual studio Ultimate 2012。利用ASP.NET和Microsoft Sql Server 2008 R2(RTM) 技术实现的B/S模式的ERP的解决方案。关键词:计算机技术 ERP ASP.NET Sql Server 2008 R2AbstractComputer technology has been playing an irreplaceable role in all walks of life in the 21st century. Currently with more and more business, enterprises and institutions having applied computer technology to daily management, technological advances indicated mainly by information technology has been occurring every day and the transformation from high-tech achievements to real productivity has been faster and faster. The material supply management is often very complicated because of the variety of materials, variation in order, management and distribution channels, distinct management systems within each company and large amount of statistical planning reports. Therefore, to enhance work efficiency material management must be computerized and designed in accordance with each enterprises specific condition while the traditional management method which relies on the management personnel to transmit information and data is not able to meet the growing needs of enterprises. Considering the current problem and the actual situation, a management website with the part function of Enterprise Resource Planning is designed to reduce the implementation cost and risk, accelerate implement progress and increase return on investment. This management system is based on the model of WEB page and B/S(Browser/Server)and uses the programming tool of Visual studio Ultimate 2012. It uses the ERP solution of B/S mode which is achieved by ASP.NET and Microsoft Sql Server 2008 R2(RTM). Key words: Computer technology ERP ASP.NET Sql Server 2008 R2 目录第一章 绪论11.1 ERP管理系统开发背景简介11.2 ERP管理系统B/S结构1第二章 相关技术与开发工具简介12.1 Microsoft Sql Server 2008 R2(RTM)简介12.2 Visual studio Ultimate 2012开发环境简介2第三章 中小型商业企业ERP管理系统设计分析23.1 设计思想23.2 系统可行性分析23.2.1 操作可行性23.2.2 经济可行性33.2.3 技术可行性33.3 系统功能模块划分33.4 数据流图33.5 系统数据库分析与设计3第四章 中小型商业企业ERP管理系统应用程序设计84.1 登入页面84.2 进货管理94.2.1 添加用户94.2.2 管理用户104.3 进货管理104.3.1 添加进货104.3.2 进货历史查114.4 销售管理114.4.1 销售单114.4.2 销售单管理164.5 基本资料管理214.5.1 添加仓库214.5.2 仓库管理224.5.3 添加供货商224.5.4 供货商管理224.5.5 添加客户234.5.6 客户管理234.5.7 添加商品244.5.8 商品管理244.6 财务报表244.6.1 盘点报表244.6.2 总收益报表28第五章 系统测试运行325.1 测试计划及过程325.1.1 添加用户测试325.1.2 用户状态修改测试325.1.3 添加销售单测试325.1.4 销售单状态修改测试325.2 模块测试总结33第六章 系统的优缺点33总 结33致 谢34参考文献35第一章 绪论1.1 ERP管理系统开发背景简介 ERP管理系统是用计算机管理库存进出的一种计算机应用技术的创新,在计算机还未普及之前库存管理、人员管理等都是由工作人员手工书写的方式来操作的。产品的采购、库存、销售等信息的管理存在工作量大、工作效率低下、耗费人员过多等问题,从而导致劳力资本投入量大、市场及消费者的反馈信息不能及时处理等。ERP管理系统充分发挥信息技术的优势,它是整合了企业管理理念、业务流程、基础数据、人力物力、计算机硬件和软件于一体的企业资源管理系统。通过对本次需求的了解我们需要通过集中式的信息数据库,将企业的进,销,存,财务、统计、报表、系统管理等经营业务有机的结合起来,达到数据共享,降低成本,提高效率,改进服务的目的,进而提高企业的生产效率和管理水平。 1.2 ERP管理系统B/S结构 本系统采用B/S设计模式,B/S (Brower/Server)模式又称B/S结构,是软件系统体系结构的一种。B/S是WEB兴起后的一种网络结构模式,WEB浏览器是客户端最主要的应用软件。这种模式统一了客户端,将系统功能实现的核心部分集中到服务器上,简化了系统的开发、维护和使用。客户机上只要安装一个浏览器(Browser),如firefox或Internet Explorer,服务器安装Oracle、Sybase、Informix或 SQL Server等数据库。浏览器通过Web Server 同数据库进行数据交互。第二章 相关技术与开发工具简介本系统使用开发软件Visual studio Ultimate 2012进行开发,使用Microsoft Sql Server 2008 R2(RTM)作为后台数据库设计,利用ASP.NET语言编写代码,配合功能强大的SQL查询语言实现建立关系数据库,访问数据库,对数据库的更新。2.1 Microsoft Sql Server 2008 R2(RTM)简介Microsoft Sql Server 2008 R2 是关系数据库开发工具,我们使用它来开发和设计所需要的数据库。Microsoft Sql Server 2008 R2 能提供超大型系统所需的数据库服务。大型服务器可能有成千上万的用户同时连接到 Microsoft Sql Server 2008 R2 实例。Microsoft Sql Server 2008 R2 为这些环境提供了全面的保护,具有防止问题发生的安全措施。可以在一台计算机上运行多个 Microsoft Sql Server 2008 R2 实例。Microsoft Sql Server 2008 R2 应用程序可在装有 Microsoft Sql Server 2008 R2 的计算机上运行。该应用程序通过 Windows 进程间通讯 (IPC) 组件(例如共享内存)而非通过网络连接到 Microsoft Sql Server 2008 R2。2.2 Visual studio Ultimate 2012开发环境简介Microsoft Visual Studio 2012 Ultimate旗舰版(vs20121)是一个最先进的开发解决方案,它使各种规模的团队能够设计和创建出使用户欣喜的引人注目的应用程序。在Visual Studio 2012旗舰版(VS2012)中您可以使用灵活敏捷的规划工具(如容量规划、任务板和积压工作管理)来按照您自己的进度实现增量开发技术和敏捷方法。Visual Studio 2012 作为一个集成解决方案,适用于无论是个人或者各种规模的开发团队。Visual Studio 2012实现了同事间的无缝协作,提高了生产效率与专注度,最终好的点子变成了优秀的现实应用。您可以使用灵活敏捷的规划工具(如容量规划、任务板和积压工作管理)来按照您自己的进度实现增量开发技术和敏捷方法。Visual Studio 2012 是一个综合性产品系列,适用于每一位希望升级或创建精彩应用程序的组织、团体和个人开发人员。 VS2012 通过整合先前单个产品中的功能并为每个版本加入新的强大功能,简化了产品系列,并且,它更加适合用于开发 Windows8 专用程序。第三章 中小型商业企业ERP管理系统设计分析3.1 设计思想第一步就是需要利用SQL Server 2008R2建立所需要的关系数据库,第二步就使用Visual studio Ultimate 2012完成该系统的开发。将建立数据库所在的服务器作为服务器端,在这里我所用的是本地服务器,为开发的Web应用程序的提供所需要的数据服务。当然,具体来说就是指Web应用开发程序和数据库的连接,本系统主要是通过ADO.NET来访问SQL Server 2008R2数据库3.2 系统可行性分析可行性分析是系统分析阶段的第二项活动,它的主要目是进一步明确系统的目标、规模与功能,对系统开发背景、必要性和意义进行了调查分析并根据需要和可能提出开发系统的初步方案与计划。可行性分析是对系统进行全面、概要的分析。通过调查分析,本系统设计主要有以下三个可行性:3.2.1 操作可行性本系统操作简单,易于理解,只需通过简单指导,上手较快,客户端只需要web浏览器即可。跨平台性比较强。3.2.2 经济可行性在经济方面,由于商场规模的日益增大,进出货物数量繁多,且工作量大。原有的手工操作耗时费力,又不能保证数据的正确性,迫切需要实现计算机信息化管理,用信息化管理实现对数据的录入、查询、打印等的处理。比起传统的方法这样可以节省大量的人力物力资源,又可以缩短业务处理的时间,加强对物资安全的管理,具有很强的实用性和经济性。3.2.3 技术可行性在技术方面,本系统采用Microsoft公司的ASP.NET以及SQL Server 2008R2设计一个既满足用户需求又操作方便而且界面友好的ERP系统web页面。ASP.NET是一种基于窗体的可视化组件安排的联合,具有强大的数据库管理功能,支持SQL数据库查询,利用ASP.NET中嵌入的数据库管理功能几乎可以操纵各种格式的数据库。3.3 系统功能模块划分根据对超市业务的管理进行分析,可得到本系统的功能模块图如图3-1所示:图3-1 系统总功能结构图3.4 数据流图 图3-2 系统数据流程图3.5 系统数据库分析与设计根据对系统数据的分析,本系统共需要11张表,用途如表3-1所示:表3-1数据库数据清单 数据表名称 数据表用途系统管理员表(T_user)保存管理员信息订单表(T_order)保存订单信息进货表(T_inventory)保存进货信息 商品表(T_product)保存商品信息现存商品表(T_extantProduct) 保存现存商品信息供货商表(T_supplier)保存供货商信息客户表(T_custorm)保存客户信息仓库表(T_warehouse)保存仓库信息订单状态表(T_orderStateName) 保存订单状态信息用户状态表(T_userStatus)保存用户状态信息仓库状态表(T_warehouseStatus)保存仓库状态信息表3-2客户表(T_custorm)序号列名数据类型长度小数位标识主键外键允许空默认值说明1custormIdint40是是否2custormNamenvarchar500是3custormTelnvarchar500是4custormAddressnvarchar500是5custormPersonnvarchar500是6custormEmailnvarchar500是表3-3 现存商品表(T_extantProduct)序号列名数据类型长度小数位标识主键外键 允许空默认值说明1Idint4 0是是否2product_Idint4 0是9warehouseint4 0是10numberint40是表3-4 进货表(T_inventory)序号列名数据类型长度小数位标识主键外键允许空默认值 说明1save_idint40是是否2product_Idint40是3number_inint40是4price_inmoney84是5supplierint40是6warehouseint40是7Time_purchasedatetime83是表3-5订单表(T_order)序号列名数据类型长度小数位标识主键外键允许空默认值说明1order_idint40是是否2order_nonvarchar500是3custormerIdint40是4productIdint40是5orderPricemoney84是6orderNumberint40是7warehouseint40是8order_datedatetime83是9stateint40是是表3-6订单状态表(T_orderStateName)序号列名数据类型长度小数位标识主键外键允许空默认值说明1idint40是否2orderNamenvarchar500是表3-7商品表(T_product)序号列名数据类型长度小数位标识主键外键允许空默认值说明1product_idint40是是否2namenvarchar500是5standardvarchar500是6unitnvarchar500是8suppliernvarchar500是9up_numberint40是10down_numberint40是11stateint40是表3-8供货商表(T_supplier)序号列名数据类型长度小数位标识主键外键允许空默认值说明1supplierIdint40是是否2supplierNamenvarchar500是3supplierTelvarchar500是4supplierAddressnvarchar500是5suppliercontactnvarchar500是表3-9系统管理员表(T_user)序号列名数据类型长度小数位标识主键外键允许空默认值说明1Idint40是是否2UserIdnvarchar1000否3UserNamenvarchar500是4UserPassWordnvarchar1000是5Emallnvarchar1000是6Statustinyint10是7warehouseint40是表3-9用户状态表(T_userStatus)序号列名数据类型长度小数位标识主键外键允许空默认值说明1userIdint40否2userStatusnvarchar200是表3-10仓库表(T_warehouse) 序号列名数据类型长度小数位标识主键外键允许空默认值说明1warehouseIdint40是是否2warehouseNamenvarchar500是3statustinyint10是表3-11仓库状态表(T_warehouseStatus)序号列名数据类型长度小数位标识主键外键允许空默认值说明1Idint40 否2Namenvarchar500 是第四章 中小型商业企业ERP管理系统应用程序设计本系统实现数据的计算输出、存盘、历史记录的显示,基础数据信息包括系统管理(添加用户、管理用户);进货管理(添加进货、历史进货查询);销售管理(销售单、销售单管理);基本资料管理(添加仓库、仓库管理、添加供货商、供货商管理、添加库户、客户管理、添加商品、商品管理);财务统计管理(盘点报表、总收益管理)等功能。本系统是由三个人一起完成,我所完成的功能是前台界面、销售管理和财务报表部分。下面我将把整个系统的功能介绍一下,然后我将我所涉及到的网页的后台思想和代码做一下详细介绍4.1 登入页面登入界面设有账号和密码,使的程序安全性更高,如图(4-1-1)所示:图 4-1-1 登陆界面4.2 系统管理在管理员账户登入的情况下,可以在系统管理中可以实现对用户的管理,可以添加用户,删除用户和对用户状态的管理。 4.2.1 添加用户添加用户的账号。姓名、密码等用户信息。如图(4-2-1):图4-2-1 添加用户信息4.2.2 管理用户可以对用户的状态、所在仓库进行管理,并且能够删除用户。如图(4-2-1):图4-2-2 用户管理4.3 进货管理用户可以通过此模块添加进货和对进货进行历史查询,添加进货可以选择所放仓库,选择供应商。4.3.1 添加进货 添加需要的商品、商品的数量价格等信息。如图(4-3-1): 图4-3-1 添加进货4.3.2 进货历史查图4-3-2 进货历史查询 4.4 销售管理用户可以通过此模块添加销售单和对销售单进行管理。4.4.1 销售单其中订货单号是日期加上每天订单的个数来确定订单的唯一性,如图(4-4-1): 图4-4-1 添加销售订单销售单部分后台代码如下:using BLL;using System;using System.Collections.Generic;using System.Data;using System.Linq;using System.Web;using System.Web.UI;using System.Web.UI.WebControls;using System.IO;using Model;using System.Data.SqlClient;namespace graduation_project public partial class sales_ticket : System.Web.UI.Page protected void Page_Load(object sender, EventArgs e) if (!IsPostBack) bing(); streamreader(); protected void bing() string productStr = " select * from dbo.T_product" DataTable dt = BLL.ProductBll.getAllProduct(productStr); productName.DataSource = dt.DefaultView; productName.DataTextField = dt.Columns1.ToString(); productName.DataValueField = dt.Columns0.ToString(); productName.DataBind(); dt = warehouseBll.getWareHouse(); orderwarehouse.DataSource = dt.DefaultView; orderwarehouse.DataTextField = dt.Columns1.ToString(); orderwarehouse.DataValueField = dt.Columns0.ToString(); orderwarehouse.SelectedIndex = 0; orderwarehouse.DataBind(); dt = BLL.custormBll.getAllCustorm(); custormer.DataSource = dt.DefaultView; custormer.DataTextField = dt.Columns1.ToString(); custormer.DataValueField = dt.Columns0.ToString(); custormer.SelectedIndex = 0; custormer.DataBind(); dt.Dispose(); public void streamreader() StreamReader sr =new StreamReader(Server.MapPath("images/data.txt"),true); string orderNumber = sr.ReadToEnd(); string date = orderNumber.Substring(0,8); string dt = DateTime.Now.ToString("yyyyMMdd"); int number = Convert.ToInt32(orderNumber.Substring(orderNumber.Length-3); if (date = dt) number+; if (number > 100) date = date + number; else date=date+number.ToString().PadLeft(3, '0'); else date = dt + "001" orderId.Text = date; sr.Dispose(); protected void submit_Click(object sender, EventArgs e) Model.order order = new Model.order(); order.P_Order_no = orderId.Text;/订单号 order.P_OrderNumber = Convert.ToInt32(orderNumber.Text);/订货数量 order.P_OrderPrice = Convert.ToInt32(orderPrice.Text);/订货价格 order.P_WarehouseId = Convert.ToInt32(orderwarehouse.SelectedValue);/出货仓库 order.P_State=0;/订单状态 order.P_Order_date = DateTime.Now;/订单时间 order.P_CustormerId=Convert.ToInt32(custormer.SelectedValue);/订单客户 order.P_ProductId=Convert.ToInt32(productName.SelectedValue);/产品名称 string sql = "insert into T_order values(order_no,custormerId,productId,orderPrice,orderNumber,warehouse,order_date,state)" int i = BLL.OrderBll.insertIntoOrder(sql, new SqlParameter("order_no", order.P_Order_no), new SqlParameter("custormerId", order.P_CustormerId), new SqlParameter("productId", order.P_ProductId), new SqlParameter("orderPrice", order.P_OrderPrice), new SqlParameter("orderNumber", order.P_OrderNumber), new SqlParameter("warehouse", order.P_WarehouseId), new SqlParameter("order_date", order.P_Order_date), new SqlParameter("state", order.P_State); int j = 0; if (i > 0) if (BLL.extantProductDal.SelectextantProduct(order.P_ProductId, order.P_Wa