欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > DOCX文档下载  

    饮料厂销售管理系统课程设计.docx

    • 资源ID:2031743       资源大小:459.07KB        全文页数:37页
    • 资源格式: DOCX        下载积分:16金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要16金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    饮料厂销售管理系统课程设计.docx

    数据库原理课程设计题 目 饮料厂销售管理系统 学 院 商学院 专 业 信息管理和信息系统 班 级 信息082 学 号 200853275237 学生姓名 许叶飞 指导教师 张细香 编写日期 2011月1月5日 目 录1 系统需求分析.1 1.1 系统调查.11.2用户需求.12 系统总体结构设计.2 2.1软件系统总体结构设计.22.2数据存储的总体设计. 22.3系统功能模块设计. 23 数据库详细设计.3 3.1数据库设计.3 3.11 E-R图设计.33.12 逻辑结构设计.5 3.2数据库的完整性和安全性.84数据库操作总代码(SQL Server2000语句完成).95 部分功能模块运行结果.29 5.1建立存储过程实现插入、删除、修改数据.29 5.2 建立存储过程实现单表查询,连接查询,嵌套查询和集合查询.306 课程设计心得.31参考文献.321 系统需求分析1.1 系统调查 对现行饮料厂销售管理业务进行详细调查是为了了解不同客户对不同产品的需求,并统计不同销售员的销售业绩。因此,我们必须对饮料厂的销售管理进行全面、细致而充分的调查研究。首先可以了解一下该厂已经生产的产品有哪些种类以及不同种类包含哪些产品,该厂目前有哪些销售员,哪些客户,以及目前的各产品的库存量。在此基础上,我们开始对该厂进行更为细致、全面、深入的调查。 通过调查,我们了解到随着时间的发展,该厂所生产的产品会增加,销售员也会增加,客户也会增加。为了适应该厂的变化,所以我们所设计出的数据库必须能够随着该厂的实际变化而变化。1.2用户需求要设计一个性能良好的管理系统,明确用户的应用环境对系统的要求是首要的和基本的。本系统从以下四个方面对用户需求进行了分析:用户的信息需求:用户能够通过单表查询、嵌套查询、集合查询等方法来查询用户信息表的信息,销售员信息表的信息,客户信息表的信息,饮料信息表的信息,订单信息表的信息,订购表的信息,仓库信息表的信息,库存表的信息和销售员总销售额表的信息。此外,用户还可以通过多表连接查询等方法来查询来自不同表的数据列值的信息。用户的处理要求:用户能够对销售员信息表、客户信息表、饮料信息表、订单信息表以及订单详细信息表等进行增加、删除和修改等操作。在客户订购饮料之后,用户可以根据目前仓库中的饮料的库存量来确定能否发货。如果可以发货,则将在库存表里扣除对应订单详细表里订购的饮料数量。如果不可以发货,则将原来的订单删除,并删除对应的订单详细信息表。当用户退订饮料之后,则将在库存表里加上对应订单详细表里订购的饮料数量。系统能够自动生成做了插入、删除或修改订单及订单详细表之后的订单的总价格和某一销售员的销售业绩。对系统的适应性、通用性要求:该系统不仅仅局限于饮料行业的销售系统,也可以移植到其他行业,进行其他行业的产品的销售管理。对系统的安全性要求,要求进入系统必须进行用户口令校验。2系统总体结构设计 2.1 软件系统总体结构设计 软件系统总体结构设计的主要任务就是将整个系统合理的划分成各个功能模块,正确处理模块之间与模块内部的联系及它们之间的调用关系和数据联系,定义各模块的内部结构等,本系统的软件总体结构按分解协调的原则,信息隐蔽抽象的原则,自顶向下的原则,一致性原则,面向用户的原则进行设计。2.2 数据存储的总体设计 按用途分类可把本系统文件分成以下几种:(1) 主文件:系统中的主文件是最重要的共享文件,主要存放具有固定值属性的数据。它需要长期保存,并不断更新。如销售员信息表、客户信息表、饮料信息表。(2) 处理文件:处理文件包含下一次更新文件所需要的全部记录,本系统中的处理文件如订单信息表、订购表、库存表。2.3系统功能模块设计通过对系统的数据流图进行分析,进一步进行功能分解,直到分解成含义明确,功能单一的功能模块,从而得到系统的功能模块结构图。如图下图饮料厂销售管理系统所示。用户登录销售员登录删除信息插入信息查看信息删除订单修改订单插入订单3 数据库详细设计 3.1数据库设计 数据库的设计是指对一个给定的应用环境,构造数据库模式,建立数据库及其应用系统,满足各种用户需求。作为信息资源开发、管理和服务的一种有效的手段,数据库技术的应用已越来越广泛,从小型的单项事务处理系统到大型的信息系统大都用先进的数据库技术来保持系统数据的安全性、完整性和共享性。对一个实际的系统来说,数据库表的设计在遵循数据库理论的同时,必须能用开发工具来实现用户在各方面提出的功能要求。3.1.1 E-R图设计 在系统的数据库设计中,先要对系统分析得到的数据字典中的数据存储进行分析,分析各数据存储之间的关系,然后才能得出系统的关系模式。可以采用E-R图的方法来进行数据结构分析,E-R设计方法是一种通过E-R图来描述现实 世界信息结构的DB设计方法。E-R图由实体、属性、联系三部分组成。总E-R图如下:部分ER图如下:(1) 销售员表E-R图见下图:(2) 客户表E-R图见下图: (3) 饮料表E-R图见下表:(4) 订单表ER图见下表: 饮料厂销售管理系统中所涉及到的主要实体集及其属性如下:用户用户编号,用户名,登录密码销售员销售员编号,销售员姓名,性别,出生年月,雇佣日期,住址, 销售员电话客户客户编号, 客户公司名称, 联系人, 公司地址, 邮政编码,客户电话饮料饮料编号,饮料名称,种类编号,种类名称,饮料单价订单订单编号,客户编号,销售员编号,订单日期订购表订单编号,饮料编号,订购数量,总价格仓库仓库编号,仓库地址库存表仓库编号,饮料编号,库存量销售员总销售额表销售员编号,总销售额3.1.2. 逻辑结构设计(E-R图向关系模型的转换) ER图向关系模型的转化要解决的问题是如何将实体和实体间的联系转换为关系模式,如何确定这些关系横式的属性和码。对于实体间的联系我们分不同的情况讨论:(1) 若实体间的联系是1:1,可以在两个实体转换成的两个关系中任意一个关系的属性中加入另一个关系的码。(2) 若实体间联系为1:n,则在n端实体转换成的关系中加入1端实体转换成的关系码。(3) 若实体间联系为n:m,则将联系转换为关系,关系的属性为诸个实体的码加上联系具有的属性,而关系的码则为诸实体的码的组合。由以上三点,可转换为关系模型。每个关系的主码用下划线表示。 用户用户编号,用户名,登录密码 销售员销售员编号,销售员姓名,性别,出生年月,雇佣日期,住址, 销售员电话 客户客户编号, 客户公司名称, 联系人, 公司地址, 邮政编码,客户电话 饮料饮料编号,饮料名称,种类编号,种类名称,饮料单价 订单订单编号,客户编号,销售员编号,订单日期 订购表订单编号,饮料编号,订购数量,总价格 仓库仓库编号,仓库地址 库存表仓库编号,饮料编号,库存量 销售员总销售额表销售员编号,总销售额基于以上关系模型,本系统中关于数据库表结构设计如下: 在服务器上用SQL Sever2000建立名为exam的数据库。其中包括以下表:用户信息表(Users),销售员信息表(Salers),客户信息表(Customers),饮料信息表(drink),订单信息表(orders),订购表(orderDetails),仓库信息表(storehouse),库存表(storetable),销售员总销售额表(TotalSales)。下面将具体介绍数据库中各个表的结构:3.2 数据库的完整性和安全性3.2.1.数据库的完整性 数据库的完整性是指数据的正确性和相容性。数据库管理系统(DBMS)用一定的机制来检查数据库中的数据是否满足规定的条件完整性约束条件,数据的约束条件是语义的体现,将作为模式的一部分存入数据库中。 本系统中定义了表与表之间的联系有助于实现完整性规则,一般在程序中实现具体的完整性控制。3.2.2.数据库的安全性 数据库的安全性是指保护数据库以防止不合法的使用所造成的数据泄漏、更改或破坏。在数据库系统中,大量的数据集中存放,而且为许多用户直接共享,是宝贵的信息资源,系统的安全保护措施就显得更为重要,它保护数据库防止恶意的破坏和非法的存取。 本系统包括数据库的安全和服务器的安全。采用管理员表示和鉴定的方法实现数据库的安全,此安全管理措施并不在前台开发工具中实现,而是在后台数据库中实现。在登录数据库时,系统让管理员户表示自己的身份,不同的管理员权限不同,系统进行核实,鉴别此管理员是否为合法用户,若是,系统进一步核实用户,通常要求用户输入口令,系统和对用户口令以鉴别用户身份。服务器的安全也是通过用户在登录服务器时输入合法的用户名和密码来实现的。这是一种简单可行的方法,实现起来比较方便。没有采用更加复杂的系统安全管理措施是因为本管理系统一般是应用在校园网中,采用安全管理措施主要是为了防止没有修改权限的用户无意间修改了数据,因此采用用户标识和鉴定的安全管理措施就能够保障数据库的安全性。4数据库操作(SQL Server2000语句完成)(1)建立数据库以及相应数据表create database drinksales gouse drinksalesgo-创建表Userscreate table Users(userID varchar(8) not null primary key,username varchar(20) null,passward varchar(8) null)go-创建表Salerscreate table Salers(saleID char(3) not null primary key,salename char(8) not null,sex char(2) default('女') null,birthday datetime null,hiredate datetime null,address char(60) null,telephone char(一三) null)go-创建表Customerscreate table Customers(customerID char(3) not null primary key,companyName char(60) not null,connectNamechar(8) null, address char(40) null,zipcode char(14) null,telephone char(一三) null)-创建表drinkcreate table drink(drinkID char(6) not null primary key,drinkname varchar(40) not null,categoryID int null,categoryname varchar(一五) null,price decimal(10,2) null)go-创建表orderscreate table orders(orderID char(4) not null primary key,customerID char(3) not null,saleID char(3) not null,orderdate datetime null)-创建表orderDetailscreate table orderDetails(orderID char(4) not null,drinkID char(6) not null,quantity int null,totalprice decimal(10,2),constraint pk_orderdetails primary key (orderID,drinkID)-创建表storehousecreate table storehouse(storehouseID char(2) not null primary key,address char(40) null)-创建表storetablecreate table storetable(storehouseID char(2) not null,drinkID char(6) not null,quantity int nullconstraint pk_storetable primary key (storehouseID,drinkID)-创建表TotalSalescreate table TotalSales(saleID char(3) not null primary key,totalprice decimal(10,2)goinsert into Users values('0001','许叶飞','s01')insert into Users values('0002','吴纯杰','s02')insert into Users values('0003','张敬杰','s03')insert into Users values('0004','罗明孔','s04')goinsert into Salers values('001','张颖','女',1968-12-10,1990-05-01,'复兴路200号','65559857')insert into Salers values('002','王伟','男',1969-02-10,1990-06-02,'罗马花园880号','65559890')insert into Salers values('003','李芳','女',1973-08-30,1990-03-19,'茶山小区11号','65557078')insert into Salers values('004','郑建杰','男',1968-09-19,1992-05-04,'前门大街一五号','65559091')insert into Salers values('005','赵军','男',1965-03-04,1993-10-一八,'学院路78号','65557773')insert into Salers values('006','孙力','男',1967-07-02,1991-02-09,'建国路102号','67756466')goinsert into Customers values('c01','三川实业有限公司','刘小姐','中山路11号','343325','83642978')insert into Customers values('c02','东南实业','王先生','承德东路87号','342783','88683829')insert into Customers values('c03','长江公司','李先生','黄山西路89号','352786','86372973')insert into Customers values('c04','国鼎有限公司','徐小姐','天台南路102号','897497','98372948')insert into Customers values('c05','盛大游戏公司','黄先生','西厢北路293号','830239','88302934')insert into Customers values('c06','申通科技','何小姐','广发西路11号','293740','88392034')insert into Customers values('c07','钱江晚报','陈先生','临江路293号','200392','88302994')insert into Customers values('c08','天鸿贸易','谢小姐','常山路290号','768594','88392000')goinsert into drink values('f01001','可口可乐',1,'碳酸饮料',3.0)insert into drink values('f01002','雪碧',1,'碳酸饮料',3.0)insert into drink values('f01003','芬达',1,'碳酸饮料',3.0)insert into drink values('f01004','醒目',1,'碳酸饮料',3.0)insert into drink values('f01005','健怡可乐',1,'碳酸饮料',3.0)insert into drink values('f01006','酷儿',1,'碳酸饮料',3.5)insert into drink values('f02001','水活森',2,'纯净水类',1.5)insert into drink values('f02002','冰露',2,'纯净水类',1.0)insert into drink values('f03001','雀巢冰爽茶',3,'茶类',3.0)insert into drink values('f03002','茶研工坊',3,'茶类',3.0)insert into drink values('f03003','原叶',3,'茶类',3.0)insert into drink values('f04001','雀巢咖啡',4,'咖啡类',一八.0)insert into drink values('f05001','果粒橙',5,'果汁类',5.8)insert into drink values('f05002','热带果粒',5,'果汁类',4.5)insert into drink values('f05003','C粒柠檬',5,'果汁类',4.5)insert into drink values('f05004','果粒奶优',5,'果汁类',4.5)goinsert into orders values('o01','c01','001',2010-10-20)insert into orders values('o02','c01','002',2010-09-27)insert into orders values('o03','c02','004',2010-08-12)insert into orders values('o04','c02','005',2010-09-10)insert into orders values('o05','c03','006',2010-09-11)insert into orders values('o06','c03','005',2010-09-一三)insert into orders values('o07','c04','002',2010-09-17)insert into orders values('o08','c04','003',2010-11-16)insert into orders values('o09','c05','003',2010-09-一八)insert into orders values('o10','c05','002',2010-09-20)insert into orders values('o11','c06','006',2010-11-11)insert into orders values('o12','c06','003',2010-11-23)insert into orders values('o一三','c07','002',2010-12-11)insert into orders values('o14','c07','005',2010-11-19)insert into orders values('o一五','c08','004',2010-09-29)insert into orders values('o16','c08','006',2010-08-19)goinsert into orderDetails values('o01','f03001',一八,0.00)insert into orderDetails values('o02','f02002',51,0.00)insert into orderDetails values('o03','f01004',25,0.00)insert into orderDetails values('o04','f02001',20,0.00)insert into orderDetails values('o05','f01005',56,0.00)insert into orderDetails values('o06','f04001',23,0.00)insert into orderDetails values('o07','f01006',11,0.00)insert into orderDetails values('o08','f05004',90,0.00)insert into orderDetails values('o09','f01001',34,0.00)insert into orderDetails values('o10','f05002',45,0.00)insert into orderDetails values('o11','f03003',41,0.00)insert into orderDetails values('o12','f05003',53,0.00)insert into orderDetails values('o一三','f01003',21,0.00)insert into orderDetails values('o14','f05001',54,0.00)insert into orderDetails values('o一五','f01002',61,0.00)insert into orderDetails values('o16','f03002',74,0.00)goinsert into storehouse values('s1','中山路46号')goinsert into storetable values('s1','f01001',400)insert into storetable values('s1','f01002',400)insert into storetable values('s1','f01003',400)insert into storetable values('s1','f01004',400)insert into storetable values('s1','f01005',400)insert into storetable values('s1','f01006',400)insert into storetable values('s1','f02001',400)insert into storetable values('s1','f02002',400)insert into storetable values('s1','f03001',400)insert into storetable values('s1','f03002',400)insert into storetable values('s1','f03003',400)insert into storetable values('s1','f04001',400)insert into storetable values('s1','f05001',400)insert into storetable values('s1','f05002',400)insert into storetable values('s1','f05003',400)insert into storetable values('s1','f05004',400)goinsert into TotalSales values('001',0.00)insert into TotalSales values('002',0.00)insert into TotalSales values('003',0.00)insert into TotalSales values('004',0.00)insert into TotalSales values('005',0.00)insert into TotalSales values('006',0.00)go(2)创建外键约束 alter table orders add constraint fk_orders_Salers foreign key (saleID) references Salers (saleID),constraint fk_orders_Customers foreign key (customerID) references Customers (customerID) onupdate cascadegoalter table orderDetails add constraint fk_orderDetails_drink foreign key (drinkID) referencesdrink (drinkID) on update cascadego(3)输出表中所有的信息-查询用户信息select * from Usersgo-查询销售员信息select * from Salersgo-查询客户信息select * from Customersgo-查询饮料信息select * from drinkgo-查询订单信息select * from ordersgo-查询订购表信息update orderDetails set totalprice=scount from orderDetails,(select top 100 percent orderID,price*quantity scount from drink,orderDetails where drink.drinkID=orderDetails.drinkID order by orderID)C where orderDetails.orderID=C.orderIDselect * from orderDetailsgo-查询仓库信息select * from storehousego-查询库存表信息select * from storetablego-查询销售员总销售额信息update TotalSales set totalprice=ccount from TotalSales,(select saleID,sum(price*quantity) ccountfrom orderDetails,drink,orders where orderDetails.drinkID=drink.drinkID and orderDetails.orderID=orders.orderID group by saleID)Cwhere TotalSales.saleID=C.saleIDselect * from TotalSales order by totalprice descgo(4)建立查询统计视图-统计所有订单的总金额create view sum1asselect sum(totalprice) 所有订单总金额 from orderDetailsgo-按照订单编号的查询统计总金额create view sum2asselect orderID,sum(totalprice) 按照订单编号统计的总金额 from orderDetails group by orderIDgo-按照销售员的查询统计总金额create view sum3asselect saleID,totalprice 按照销售员的查询统计总金额 from TotalSalesgo-按照客户的查询统计总金额create view sum4asselect customerID,sum(totalprice) 按照客户的查询统计总金额 from orderDetails,orders where orderDetails.orderID=orders.orderID group by customerIDgo-按照产品的查询统计总金额create view sum5asselect drinkID,sum(totalprice) 按照产品的查询统计总金额 from orderDetails group by drinkIDgo-按照产品分类的查询统计总金额create view sum6asselect categoryID,sum(totalprice) 按照产品分类的查询统计总金额 from orderDetails,drink where orderDetails.drinkID=drink.drinkID group by categoryIDgo(5)建立存储过程插入、删除、修改数据-向Salers表插入数据create proc insertSalers xsaleID char(3),xsalename char(8),xsex char(2),xbirthday datetime,xhiredate datetime,xaddress char(60),xtelephone char(一三)asdelete from Salers where saleID=xsaleID insert into Salers values(xsaleID,xsalename,xsex,xbirthday,xhiredate,xaddress,xtelephone)go-向Customers表插入数据create proc insertCustomersxcustomerID char(3),xcompanyName char(60),xconnectName char(8),xaddress char(40),xzipcode char(14),xtelephone char(一三)asdelete from Customers where customerID=xcustomerID insert into Customer values(xcustomerID,xcompanyName,xconnectName,xaddress,xzipcode,xtelephone)go-向drink表插入数据create proc insertdrinkxdrinkID char(6),xdrinkname varchar(40),xcategoryID int,xcategoryname varchar(一五),xprice decimal(10,2)asdelete from drink where drinkID=xdrinkIDinsert into drink values(xdrinkID,xdrinkname,xcategoryID,xcategoryname,xprice)go-向orders表插入数据create proc insertordersxor

    注意事项

    本文(饮料厂销售管理系统课程设计.docx)为本站会员(小飞机)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开