销售管理与智能分析系统 毕业论文.doc_第1页
销售管理与智能分析系统 毕业论文.doc_第2页
销售管理与智能分析系统 毕业论文.doc_第3页
销售管理与智能分析系统 毕业论文.doc_第4页
销售管理与智能分析系统 毕业论文.doc_第5页
已阅读5页,还剩16页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

编号:大学本科毕业论文销售管理与智能分析系统论文作者姓名: 作 者 学 号: xxxxxx 所 在 学 院: xxxxxxxxxxxxxxxxxx 所学专业: xxyjskx 导师姓名职称: xxxxxxxxxxx 论文完成时间: 2011年5月8日 2011年5月13日销售管理与分析系统 摘 要:本文销售管理与分析系统,研究了销售的统计和智能分析,设计并开发了一套管理系统。该系统的优势在于:打破常规表格浏览数据方式,采用新的直方图的方式,将数据以直方图的形式显示出来,能帮助管理者更直观,更方便的观察销售数据的变化;能根据已有的销售记录预测未来一段时间内的销售情况。关键词:销售数据管理;仓库管理;数据统计;数据预测1 引言销售数据管理系统随着信息化时代的到来和企业不断发展的需要,在国内外都有很大的市场和研究空间。现有的销售数据管理系统主要是对于大型数据仓库和中小型数据仓库的研究。有关大型数据仓库的管理系统大多为企业内部自己开发,其针对性比较强,功能也比较完善,但是他的数据模型也很难运用到其他行业数据仓库的管理,其通用性很差,并且开发成本也比较昂贵。对于中小型数据仓库的管理系统,市场上有很多。他们的大部分功能都相差不远。这些管理系统只具备常规的数据管理,维护功能。对于更有价值的数据统计,数据预测功能,这些系统通常是不具备的。即使有少数的系统可能做过这些方面的研究,但是其数据显示模式也是常规的表格形式。这种表格数据让企业决策者很难从中找到潜在的市场价值。相对于中小型企业来说,数据统计和数据预测功能,直观的数据显示形式,常常都是很受欢迎的。而具有这些功能的比较完善的系统市场上少之又少。这些企业为了生存不会开发针对其自身行业领域的专门系统。而为了在行业内竞争中获利,这些中小型企业非常需要廉价的功能完善的系统。显然这些与市场上的产品空白形成了矛盾。针对国内外研究现状的分析,对于中小型销售数据仓库管理的研究,本系统提出了新的开发模型。2 系统需求分析 需求分析在系统中占有重要地位。需求分析就是通过与用户的广泛交流,得到未来系统必须具备的功能,即了解未来系统必须做什么,定义系统功能和用户界面,使客户了解系统,开发人员了解系统需求,同时作为制定项目计划的基础。所以说只有好的系统分析才能做出一个好的系统。2.1业务需求分析基本的需求主要包括:对数据基本信息的管理,对销售明细的查询,统计,基本业务报表的输出和打印,数据维护,对未来销售状况的预测,等。主要联系是:管理员人事信息员工工资商品信息销售记录数据维护报表打印数据查询信息管理智能预测图2-1 系统需求联系图2.2功能需求分析根据以上业务需求分析,在加上相关的系统用户注册,密码找回,帮助系统,可以总结出功能需求。如下图所示:销售管理系统登录模块基本信息管理信息查询数据统计报表打印智能分析帮助注册密码找回人事信息员工工资商品信息销售记录商品信息销售情况员工名单商品订单销售记录图2-2 系统模块联系图2.3系统性能分析1.系统必须稳定,具有较高的可靠性和容错性 整个系统必须具备很高的安全性,达到可靠稳定,不易出错,容易修复,并且不能影响正常使用。2.系统软件功能必须完善,便于管理和维护整套销售管理系统必须能满足用户的需求,便于操作,界面简洁,且易于维护。3.系统需预留与其他系统的接口为了适应业务增长的需求,系统需要考虑以后功能的扩充,以及与其他系统的连接等问题。3 数据库设计数据库是存放数据及相关信息的仓库,是事务处理,信息管理等应用系统的基础。数据库设计的意义关系到系统开发的成败。本系统采用关系模型建立数据库。关系模型以二维表格的形势组织数据库中的数据。3.1数据采集系统的原始数据主要来源于网络上的中小型企业。这些数据只是企业内部数据的一部分。由于论文的目的主要是提供给开发者一个可以借鉴的模型,并与传统的模型形成对比,一发现其优点所在。对于系统的研究开发这些数据已经足够了。3.2 e-r数据图人事信息和员工工资的e-r模型:员工员工号姓名出生日期学历职位联系方式地址身份证号工资总额奖金基本工资属于图3-1 人事信息和员工工资的e-r图商品信息和销售记录的e-r模型:商品类别数量进入价格商品名称商品代码库存量卖出价格销售日期销售年月销售记录号商品销售记录销售图3-2 商品信息和销售记录的e-r图管理员信息包括:员工号,密码,权限,密保问题,密保答案。3.3数据表划分及逻辑结构根据e-r模型,可以对数据表划分及确定逻辑结构。人事信息表(workers):列名数据类型主键允许空员工号varchar(30)是否姓名varchar(30)否否性别varchar(50)否否出生日期datetime否否身份证号varchar(30)否否地址varchar(30)否否联系方式varchar(30)否否职位varchar(30)否否学历varchar(30)否否员工工资表(salary):列名数据类型主键允许空员工号varchar(30)是否姓名varchar(30)否否身份证号varchar(30)否否工资float否否奖金float否否总额float否否商品信息表(products):列名数据类型主键允许空商品代码varchar(30)是否商品名称varchar(30)否否商品类别varchar(30)否否进入价格float否否卖出价格float否否库存量float否否销售记录表(productdetails):列名数据类型主键允许空销售记录号bigint是否商品代码varchar(30)否否商品名称varchar(30)否否商品类别varchar(30)否否销售数量float否否销售年月datetime否否管理登录表(users):列名数据类型主键允许空员工号varchar(30)是否密码varchar(30)否否权限varchar(30)否否密保问题varchar(30)否否密保答案varchar(30)否否4 总体设计总体设计主要解决在系统设计中,所涉及到的前台数据流程控制,后台数据库,视图的创建,以及matlab建模程序设计。4.1总体分析前面已经分析过功能需求,在其中的数据统计,报表打印等模块要用到大量的视图。接着上一章的数据库创建后,接下来主要说明系统中所用到的视图的创建,智能分析模块的理论基础,以及相关的matlab程序设计。4.2前台数据流程统计模块:包含,商品信息统计,销售记录统计。由于统计模块的显示模式有两种(常规表格,图形显示),所以为了减少编程负担,精简程序,使商品信息统计和销售记录统计都采用一个处理模型。针对常规表格模式,采取调用数据库命令的形式;对于图形显示模型,主要是将统计条件存储到视图中,然后打开图形绘制窗体,读取视图中的数据并以图形的形式显示出来。智能分析模块:包括,商品盈亏分析,商品销售预测,总盈亏分析。商品盈亏分析和总盈亏分析的数据流程主要是,视图统计,然后计算,最后显示结果。商品销售预测的数据流程比较复杂,在预测数据时需要把将要预测的商品信息存储到视图中,然后由程序读取,传递给已经编制好的matlab程序生成的组件,有这些组件计算要预测的信息。4.3后台数据库和视图支持下面是各个模块中所用到的数据视图,辅助视图,及各视图的创建代码:/生成商品订单数据源的辅助视图create view productdd2 as select 商品代码,max(销售年月) as 销售年月 from productdd1 group by 商品代码 go/生成商品订单数据源的辅助视图create view productdd3 as select a.商品代码,a.商品名称,a.销售总量,b.销售年月 from productdd1 a,productdd2 b where a.商品代码 = b.商品代码 and a.销售年月 = b.销售年月 go/生成商品订单数据源create view productdd as select a.商品代码,a.商品名称,a.商品类别,a.库存量,b.销售总量 as 总销售量,b.销售总量-a.库存量 as 订购量,b.销售年月 from products a,productdd3 b where a.商品代码 = b.商品代码 go智能预测模块:/智能预测所用视图/用于辅助计算-求总销售额create view znfxz as select 商品名称,sum(销售额)as 总销售额from productdetails group by 商品名称 go/用于辅助计算-求净利润create view znfxz1 as select a.商品名称,a.总销售额 * (b.卖出价格 - b.进入价格)/b.卖出价格 as 净利润 from znfxz a,products bwhere a.商品名称 = b.商品名称 go-验证是否可预测用的辅助模块视图create view viewzn as select 商品代码,商品名称,销售年月,sum(销售额) as 月销售额 from productdetails group by 商品代码,商品名称,销售年月 go/验证是否可预测用的模块视图/如果记录条数小于8,则不能预测销售数据create view viewznjl as select 商品代码,商品名称,count(*) as 记录条数 from viewzn group by 商品代码,商品名称 go/分析模块用的视图alter view viewznfx as select 商品名称,(datediff(month,cast(1996-1-1 as datetime),cast(销售年月 as datetime) as 月数,sum(销售额) as 月销售额,销售年月from productdetails where 商品名称 = 牛奶 group by 商品名称,销售年月 go4.4 matlab程序设计在智能分析的数据预测功能中,要使用到最小二乘法。在已有销售记录的基础上使用最小二乘法可以预定制定时间的销售额。下面详细说明最小二乘法拟合的matlab实现。最小二乘法拟合:在这里系统选用最小二乘法拟合多项式函数,次数去2。下面是系统中用到的matlab程序:function result = tnh(a,b,x) k = polyfit(a,b,2); result = polyval(k,x);end在程序中a为某个商品的最近8个销售记录时间距离1996-01-01的月数;b为对应a中每个月的销售额;x为要预测的日期距离1996-01-01的月数。以上模型为最小二乘法,针对不同的企业和销售模式其数据预测可能需要不同的模型,本系统是调用matlab生成的组件,传递给模型数据,然后得出结果。为了给系统提供更好的适应性,如果需要不同的预测模型,可以直接建模后用matlab程序生成组件,更换掉原来的组件即可运行。5 详细设计详细设计将描述系统中各个模块的操作流程,界面设计,以及实现程序代码。5.1 登录模块登录模块通过用户名和密码检查用户是否合法,同时使用验证信息防止恶意登录。下面是登录窗体(logn)的显示界面:图5-1 登录窗体界面图其中员工号和密码是用户在注册中填写的信息,验证信息为随即生成的两个1-9的整数组成的运算式,只有用户输入正确的员工号,密码,并且在验证框中输入正确的结果后方能进入系统。5.2 注册模块在登录窗体(logn)中点击注册用户就可以启动注册用户窗体。下面描述用户注册流程:输入信息数据合法?更新users注册成功关闭注册,显示登录是否已注册?是否为公司员工?二次密码是否一致?重新输入否是否否是是是否图5-2 用户注册模块数据流程图 图5-3 用户注册窗体界面图5.3 密码找回模块在登录窗体(logn)中点击密码找回就可以启动密码找回窗体。下面描述密码找回流程:输入员工号是否有此人显示密保问题输入答案答案是否正确输入密码两次密码一致保存密码否是是是否否重新输入图5-4 密码找回模块数据流程图 图5-5密码找回窗体界面图5.4 主菜单模块主菜单模块主要是为其他各个功能模块提供操作界面,其界面如下:图5-6 主菜单窗体界面图主菜单模块代码比较简单,此处不再详述。5.5 基本信息管理模块该模块包括人事信息管理,员工工资管理,商品信息管理,其代码大致相同,此处只对人事信息管理列出代码:人事信息管理界面:图5-7 人事信息管理窗体界面图人事信息管理主要代码: /flag变量用于控制新建按钮是否可用 /为防止出现异常 /每次插入新的行后都要保存一次后才能再次插入 int flag = 1; private void workersbindingnavigatorsaveitem_click(object sender, eventargs e) try this.validate();this.workersbindingsource.endedit();this.tableadaptermanager.updateall(this.epdatedataset); flag = 1; messagebox.show(保存成功!); catch (exception err) messagebox.show(err.message);/-保存- private void workersbindingnavigatorsaveitem_click_1(object sender, eventargs e) if (yznotnull()trythis.validate(); this.workersbindingsource.endedit(); this.tableadaptermanager.updateall(this.epdatedataset); flag = 1; messagebox.show(保存成功!); catch (exception err) messagebox.show(err.message); else messagebox.show(有数据项为空,请填写完整的数据后再保存!);return; private bool yznotnull() if(出生日期datetimepicker.value=null|地址textbox.text=|联系方式textbox.text=|身份证号textbox.text=|姓名textbox.text=|性别textbox.text=|学历textbox.text=|员工号textbox.text=|职位textbox.text=) return false; elsereturn true; /-添加新行- private void bindingnavigatoraddnewitem_click(object sender, eventargs e) if (flag = 0) return; elseflag = 0; bindingnavigatoraddnewitem.enabled = false;5.6 查询模块该模块包括人事信息查询,员工工资查询,商品信息信息,销售记录查询,其代码大致相同,此处不再详述。销售记录查询界面:图5-8 销售记录查询窗体界面图5.7 统计模块统计模块包括商品信息统计,销售记录统计。统计结果显示形式有表格形式,直方图形式。在代码上商品信息统计,销售记录统计大致相同。此处只列出销售记录的代码和图形。销售记录统计界面(表格模式):(图中为白米的销售额统计情况)图5-9 销售情况数据统计窗体界面图销售记录统计界面(直方图模式):(图中为海苔酱的销售量直方图)图5-10 数据统计模块直方图显示模式窗体界面图销售记录主要代码:/-显示统计结果-private void button1_click(object sender, eventargs e) /如果没有选商品类别,返回 if (combobox1.selectedindex = -1 | combobox2.selectedindex = -1) messagebox.show(请选择商品类别和商品名称); return; string cmdstring; sqlconnection conn = new sqlconnection(properties.settings.default.epdateconnectionstring);/-如果选择的是直方图模式,调整视图数据,打开图形显示窗体 if (radiobuttonzft.checked = true) c3tjdraw form = new c3tjdraw(); c3tjdraw form1 = new c3tjdraw(); /调整视图数据 cmdstring = alter view viewtj as select 销售年月,sum(销售额) as 月销售额 from productdetails where 商品名称 = + combobox2.selecteditem.tostring() + group by 销售年月 ; sqlcommand cmd = new sqlcommand(cmdstring, conn); tryconn.open();cmd.executenonquery(); catch (exception err) messagebox.show(err.message); return; finallyconn.close();form.close();form1.show(); return;/-如果是常规模式,则在表中显示数据 cmdstring = select 商品代码,商品名称,销售年月,sum(销售额)as 月销售额 from productdetails where 商品名称 = + combobox2.selecteditem.tostring() + group by 商品代码,商品名称,销售年月;sqldataadapter adapter = new sqldataadapter(cmdstring, conn); datatable table = new datatable(); tryadapter.fill(table); datagridview1.datasource = table; catch (exception err) messagebox.show(err.message); 图形绘制模块的主要代码:sqldataadapter adapter = new sqldataadapter(); datatable table = new datatable(); private void c3tjdraw_load(object sender, eventargs e) /-读取视图到表table中,供后续调用 sqlconnection conn = new sqlconnection(properties.settings.default.epdateconnectionstring); string search = select * from viewtj go; adapter = new sqldataadapter(search,conn); adapter.fill(table); /-绘图- private void c3tjdraw_paint(object sender, painteventargs e) /-设置变量 int h1, h2, w1, w2, wd, hd, yl, xl, yd, xd, rd, clmnb; decimal rk; int maxvalue = 1; int c1, c2, cwidth, cheight; string xstring; string ystring; /-给变量赋值 h1 = 20; h2 = 110; w1 = w2 = 50; wd = 30; hd = 10; yl = this.height - h1 - h2; xl = this.width - w1 - w2; yd = 50; xd = 50; clmnb = table.rows.count; /-查找列中最大值 for (int i = 0; i maxvalue) maxvalue = convert.toint16(table.rowsi1); rk = convert.todecimal(convert.todecimal(yl - yd) /convert.todecimal(maxvalue); rd = (xl-xd)/(2*clmnb); /-绘制坐标轴 graphics g = e.graphics; pen blackpen = new pen(color.lightblue, 2.0f); blackpen.startcap = linecap.flat; blackpen.endcap = linecap.arrowanchor; /画出直线 g.drawline(blackpen, new point(w1, this.height - h2), new point(this.width - w2, this.height - h2); g.drawline(blackpen, new point(w1, this.height - h2), new point(w1, h1); /x,y坐标标示g.drawstring(table.columns0.columnname.tostring(), this.font, brushes.black, this.width - w2-10, this.height - h2 +5);g.drawstring(table.columns1.columnname.tostring(), this.font, brushes.black, w1+5, h1); /-绘制图形 solidbrush bluebrush = new solidbrush(color.lightblue); for(int i = 1;i= 4) ystring = ystring.substring(0, 4); /-绘制,填充直方图g.drawrectangle(blackpen,c1,c2,cwidth,cheight);g.fillrectangle(bluebrush,c1,c2,cwidth,cheight); /-绘制标示/直方图标示g.drawstring(ystring, this.font, brushes.black, c1, c2 - wd); system.drawing.stringformat drawformat = new system.drawing.stringformat(stringformatflags.directionvertical); g.drawstring(xstring,this.font,brushes.black,c1,this.height-h2 +hd,drawformat);其中部分变量的意义请看下图:h1ydwdw1h2hdxdw2图5-11 直方图显示窗体程序变量示意图5.8 报表打印模块报表打印模块包括员工名单,商品订单,销售记录情况。关于报表的制作,三者基本相同,此处不再累述。下面只显示商品订单的信息。商品订单报表界面:图5-12 商品订单报表窗体界面图5.9 数据维护模块数据维护主要是通过调用数据库命令将数据库中的数据备份到指定的位置,以供数据恢复是使用。用户单击数据备份后选择保存位置后就可以将数据库的备份保存到指定位置。数据恢复工作可以在sql server 2005 中通过还原数据库完成。5.10 智能分析模块该模块有三个功能商品盈亏分析,商品销售预测,总销售盈亏分析。商品盈亏分析的运行结果如下:(下图为系统对番茄酱的销售情况的分析)图5-13 智能预测商品盈亏分析窗体界面图从图中可以看出番茄酱的目前总盈利7835.835元,净利润占销售额的百分比为:40.05692%,可见已达到目标销售范围,系统建议继续销售。商品销售预测的运行结果如下:(下图为对番茄酱的销售情况的分析)图5-14 智能预测商品销售预测窗体界面图从图中可以看出番茄酱在1999年4月的销售额预计为326.2292。总销售盈亏的运行结果如下:图5-15 智能预测总销售盈亏分析窗体界面图到目前为止,公司销售额为1258488元,净利润为545404.9元,净利润占销售额百分比为43.33811%。以上模块的主要实现代码如下: /-商品盈亏分析- private void button1_click(object sender, eventargs e) if (combobox2.selectedindex = -1) messagebox.show(请选择要分析的商品!); return; richtextbox2.text = ; string pd; float zxse; float jj; float mj; float jlr; float jlb; try /求商品的总销售额 sqlconnection conn = new sqlconnection(properties.settings.default.epdateconnectionstring); string search = select sum(销售额) as 销售额 from productdetails where 商品名称 = + combobox2.selecteditem.tostring() + group by 商品名称; sqldataadapter adapter = new sqldataadapter(search, conn); datatable table = new datatable(); adapter.fill(table); zxse = (float)convert.todouble(table.rows00); /求进入价格,卖出价格 search = select 进入价格,卖出价格 from products where 商品名称 = + combobox2.selecteditem.tostring() + ; sqldataadapter adapter1 = new sqldataadapter(search, conn); datatable table1 = new datatable(); adapter1.fill(table1); jj = (float)convert.todouble(table1.rows00); mj = (float)convert.todouble(table1.rows01); /显示结果 jlr = zxse * (mj - jj); jlb = (mj - jj) / mj * 100; if (jlb 10) pd = 该商品已处于亏损状态,应当立即调整价格或停止出售!; else if (jlb 40) pd = 不在目标盈利范围,建议调整价格!; else pd = 达到目标销售范围,建议继续保持销售!; richtextbox2.text= + combobox2.selecteditem.tostring() + 商品目前总盈利: + jlr.tostring() + 净利润占销售额百分比: + jlb.tostring() + % ;richtextbox2.text = richtextbox2.text + pd; catch(exception err) messagebox.show(err.message); /-总盈亏分析- private void button3_click(object sender, eventargs e) richtextbox2.text = ; float zxse; float jlr; float jlb; string pd; try/求总销售额 sqlconnection conn = new sqlconnection(properties.settings.default.epdateconnectionstring); string search = select sum(总销售额) from znfxz; sqldataadapter adapter = new sqldataadapter(search, conn); datatable table = new datatable();adapter.fill(table); zxse = (float)convert.todouble(table.rows00); /求净利润 search = select sum(净利润) from znfxz1; sqldataadapter adapter1 = new sqldataadapter(search, conn); datatable table1 = new datatable(); adapter1.fill(table1); jlr = (float)convert.todouble(table1.rows00); /显示结果 jlb = jlr*100/zxse; if (jlb 40) pd = 商店处于低盈利状态,应当调整销售策略!; else pd = 达到目标盈利范围,建议继续保持销售!; richtextbox2.text = 销售总额为: + zxse.tostring() + 净利润为: + jlr.tostring() + 净利润占销售总额比例为: + jlb.tostring() + % !; richtextbox2.text = richtextbox2.text + + pd; catch (exception err) messagebox.show(err.message); /-智能预测- private void button2_click(object sender, eventargs e) cursor.current = cursors.waitcursor; richtextbox2.text = ; if (combobox2.selectedindex = -1 | datetimepicker1.value = null) messagebox.show(请选择完整的分析条件!); return; /-定义变量 float a = 0,0,0,0,0,0,0,0;float b = 0, 0, 0, 0, 0, 0, 0, 0; int x; string search; int jlcount; /-提取数据/求商品的销售记录数 sqlconnection conn = new sqlconnection(properties.settings.default.epdateconnectionstring); try search = select * from viewznjl where 商品名称 = + combobox2.selecteditem.tostring() + ; sqldataadapter adapter = new sqldataadapter(search, conn); datatable table = new datatable();adapter.fill(table); jlcount = (int)conv

温馨提示

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

评论

0/150

提交评论