《数据库课程设计》课程设计外贸公司的订单管理系统_第1页
《数据库课程设计》课程设计外贸公司的订单管理系统_第2页
《数据库课程设计》课程设计外贸公司的订单管理系统_第3页
《数据库课程设计》课程设计外贸公司的订单管理系统_第4页
《数据库课程设计》课程设计外贸公司的订单管理系统_第5页
已阅读5页,还剩8页未读 继续免费阅读

下载本文档

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

文档简介

1、杭州电子科技大学数据库课程设计课程设计手册 外贸公司的订单管理系统姓 名 学 号 07031760 设计小组长 其 他 设 计小 组 成 员 指 导 教 师 设 计 时 间 2009.9.7 至 2009.9.18 杭州电子科技大学管理学院编制一、需求分析1.针对外贸企业的订单管理系统,分别对商品、订单、订单明细、客户、生产商和供应商在整个订单管理系统中的定位进行详细的分析,获得其需求信息如下:订单的接收是按照商品分类进行的,所以需要有每个商品的信息。登记于同一张订单明细的必须是同一种商品。如果一个商品的订单有一个或者多个胜生产商满足,则该订单不可被退回。需要完整地记录商品、客户、生产商、供应

2、商的信息。针对每一笔业务,在订单中的商品信息栏中都要仔细的纪录每一种商品的编号、日期、数量、单价和总价。在每一张订单中都要详尽的纪录下订单的单位名称、单位号、单位地址、交货日期、货品名称、货品号、货品单价和货品总价。把所有相同的产品纪录到同一张订单明细表中,每一张订单明细表中只能纪录同一种商品。在每一张订单明细表中需要纪录订单号、单位名称、商品号、商品名、规格、交货日期、数量、单价和签订日期等。根据货品名称、交货日期、货品数量、生产商的生产能力以及单位地址等实际因素,将订单明细表进行合理的合并和拆分,从而达到降低成本的目的。对接收订单的货品的生产商以及货品的供应商信息进行详尽的纪录。订单的接收

3、、处理要有相应的业务员信息。只有管理员登录之后才可以使用系统。默认的管理员不可以删除。可以对作废的、待生产的、正生产的、生产完成的订单进行分类查找,但不能进行修改、添加、删除等操作。当进行订单接收和处理操作后,能相应更新数据库更新。对所接收的订单进行数据分析,总结相应商品的订单服务。2. 经上述系统功能分析和需求总结,考虑其业务和功能的不断扩展,设计如下的数据项和数据结构:商品信息,包括的数据项有: 商品号,名称,规格,单价,描述。订单明细信息,包括的数据项有: 订单号,单位名称,商品号,商品名,规格,交货日期,数量,单价,签订日期。订单信息,包括的数据项有: 订单号,单位,操作员号,地址,签

4、订日期,单价,数量,商品号,交货日期。业务员信息,包括的数据项有: 职工号,姓名,年龄,职称。客户信息,包括的数据项有:客户姓名,账号,地址,联系方式。 生产订单信息,包括的数据项有:生产商,商品名,数量,单价,账号,联系方式。供应商信息,包括的数据项有: 姓名,地址,电话号码,账号。3.数据流图订单管理系统数据流图如下: 在整个数据流图中,p1,p2,p3,p4分别是客户信息管理系统,产品信息管理系统,员工信息管理系统,供应商管理系统,我们这里只作简单处理。p5.1,p5.2,p5.3是订单管理系统的核心部分,p5.2审核系统是根据客户的信用情况,剔除一部分不合格的订单并触发修改订单明细,p

5、5.3是根据供应商的供应能力等情况对订单明细进行拆分和合并处理,最终形成生产订单。4.数据字典(1)、数据项数据项描述=职工号,char(6),000000999999,前两个数字表示所属部门,中间两个数字表示工作起始年份;姓名,varchar(8);年龄,int(2),1865,职工的年龄必须大于18周岁且小于65周岁;商品号,char(14) ,由阿拉伯数字和英文小写字母组成;单位名称,varchar(10)单位号,char(10)(2)、数据结构数据结构描述=业务员信息,组成:职工号,姓名,年龄,职称;订单信息,组成:订单号,单位号,操作员号,地址,签订日期,单价,数量,交货日期;客户信

6、息,组成:客户号,客户姓名,账号,地址,联系方式;(3)、数据流数据流描述=员工信息流,来源:人工录入,去向:员工信息表,组成:业务员信息;(4)、数据存储数据存储描述=订单明细,客户信息流,产品信息流,员工信息流,订单明细信息流,组成:业务员信息,商品信息,客户信息;(5)、处理过程处理过程描述=下单,输入:客户信息流,产品信息流,员工信息流,输出:订单明细信息流,处理:通过员工的操作,使显示具体的订单信息表和订单明细表;2、 概念模型设计订单管理系统e-r图如下:在这里,我们为了简化数据库,将订单管理设置为只处理一种商品,所以订单的拆分和合并联系分别是1:n 和n:1 。在订单明细中可以反

7、映商品的供应者,在生产订单中可以显示每个供应商的供应量等信息。生产订单属性中的生产商号和供应商供应商号为异名同义,订单明细属性中的单位名称和客户信息属性的客户姓名为异名同义。三、逻辑模型设计职工信息表属性名数据类型可否为空备注职工号char(6)否主键姓名varchar(8)否年龄int否职称varchar否订单信息表属性名数据类型可否为空备注订单号char(6)否主键单位姓名 varchar(20)否外键地址varchar(100)否商品单价money否数量int否签订日期datetime否交货日期datetime否操作员号char(6)否外键商品号varchar(10)否外键商品信息表属性

8、名数据类型可否为空备注商品号varchar(10)否主键名称varchar(20)否单价money否规格varchar(20)否描述varchar(50)可订单明细表属性名数据类型可否为空备注订单号char(6)否外键商品号char(10)否外键商品名varchar(20)否单价money否数量int否签订日期datetime否交货日期datetime否单位名称char(10)否外键规格varchar(20)否生产商号char(10)否外键生产订单信息表属性名数据类型可否为空备注生产商varchar(20)否外键地址varchar(100)否单价money否账号varchar(20)否联系方式

9、varchar(21)否供应量int否订单号char(6)否外键商品号char(10)否外键供应商信息表属性名数据类型可否为空备注姓名varchar(20)否主键地址varchar(100)否电话号码varchar(20)可账号varchar(20)否客户信息表属性名数据类型可否为空备注客户姓名varchar(20)否主键账号varchar(20)否地址varchar(100)否联系方式varchar(20)否4、 物理模型设计(1) 、由于经常在查询条件中出现,所以决定在职工信息表中的职工号上建立唯一索引;(2) 、由于经常在连接操作的链接条件中出现,所以决定在订单信息表中的订 单号上建立唯

10、一索引;(3) 、由于经常在查询条件中出现,所以决定在客户信息表中的客户姓名上建立唯一索引;(4) 、由于经常在查询条件中出现,所以决定在供应商信息表中的姓名上建立唯一索引;(5) 、由于经常在连接操作的链接条件中出现,所以决定在商品信息表中的商品号上建立唯一索引;5、 数据库实施和维护1、 创建数据库create database 订单管理系统2、 创建表创建职工信息表create table 职工信息表(职工号 char(6) not null primary key,姓名 varchar(8) not null,年龄 int not null,职称 varchar(10) not nul

11、l,)创建商品信息表create table 商品信息表(商品号 varchar(10) not null primary key,名称 varchar(20) not null,单价 money not null,规格 varchar(20) not null,描述 varchar(50)创建供应商信息表create table 供应商信息表(姓名 varchar(20) not null primary key,地址 varchar(100) not null,电话号码 varchar(20) not null,账号 varchar(50) not null)创建客户信息表create t

12、able 客户信息表(客户姓名 varchar(20) not null primary key,账号 varchar(20) not null,地址 varchar (100)not null,联系方式 varchar(20) not null)创建订单信息表create table 订单信息表(订单号 char(6) not null primary key,地址 varchar(100) not null,商品单价 money not null,数量 int not null,签订日期 datetime not null,交货日期 datetime not null,单位 varchar

13、 (20) foreign key references 客户信息表(客户姓名),操作员号 char(6) foreign key references 职工信息表(职工号),商品号 varchar(10)foreign key references 商品信息表(商品号)创建订单明细表create table 订单明细表(订单号 char(6) not null foreign key references 订单信息表(订单号),商品号 varchar(10) not null foreign key references 商品信息表(商品号),商品名 varchar(20) not null

14、,单价 money not null,数量 int not null,签订日期 datetime not null,交货日期 datetime not null,单位 varchar(20) foreign key references 客户信息表(客户姓名),规格 varchar(20) not null,生产商 varchar (20) foreign key references 供应商信息表(姓名)创建生产订单信息表create table 生产订单信息表(地址 varchar (100) not null,单价 money not null,账号 varchar(20) not nu

15、ll,联系方式 varchar(21) not null,供应量 int not null,生产商 varchar(20) not null foreign key references 供应商信息表(姓名),订单号 char(6) not null foreign key references 订单信息表(订单号),商品号 varchar(10) not null foreign key references 商品信息表(商品号)3、创建视图create view 订单明细视图as select 订单号,单位,商品号,生产商from 订单明细表create view 生产订单视图as sel

16、ect 生产商,订单号,商品号,供应量,联系方式from 生产订单表4、 创建索引在主键属性和外键属性列上都建立索引,检查唯一性和完整性,加快连接查询速度。create unique index ix_职工号 on 职工信息表(职工号);create unique index ix_订单号 on 订单信息表(订单号);create unique index ix_客户姓名 on 客户信息表(客户姓名);create unique index ix_姓名 on 供应商信息表(姓名);create unique index ix_商品号 on 商品信息表(商品号);5、 表中数据操作1、给数据库赋

17、值insert into 职工信息表values(070934,kimikong,24,操作员);insert into 职工信息表values(070317,massa,29,主管);insert into 职工信息表values(040201,aloso,34,操作员)insert into 商品信息表values (07031760,klmin,2000,长度172cm,重量60kg,畅销货啊);insert into 商品信息表values(07031763,lljing,1500,长度165cm,体重70kg,有点胖胖);insert into 客户信息表values(雷敬文,070

18、31761,16-624;insert into 客户信息表values(李俊,07031764,16-610,1586902432);insertinto 订单信息表values(001,杭电16#624,2000,10,2009.09.15,2009.09.18,雷经文,070934,07031760)insertinto 订单信息表values(002,杭电16#625,1500,20,2009.09.14,2009.09.17,李俊,040201,07031763)insertinto 订单明细表values(001,07031760,klmin,2000,1

19、0,2009.09.15,2009.09.16,雷经文,长度172cm,重量60kg,老大)insertinto 订单明细表values(002,07031763,lljing,1500,20,2009.09.14,2009.09.17,李俊,长度165cm,重量70kg,老邱)insertinto 生产订单信息表values(杭电2,2000,166261,110转1,10,老大,001,07031760)insertinto 生产订单信息表values(杭电3,1500,166262,110转2,20,老邱,002,07031763)insertin耀 供应商信息表values(老大,杭电

20、2,110转1,166261)insertinto 供应商信息表values(老邱,杭电3,110转2,166262)2、其他操作把客户信息表中李俊的联系方式更正pdate 客户信息表set 联系方式here 客户姓名=李俊;员工因故辞职delete from 职工信息表where 职工号=0703176、 使用表格操作1、查找所有职工的年龄,并按年龄大小进行排序select 职工号,姓名,年龄from 职工信息表order by 年龄2、 查找订单号为001的商品的描述select 订单号,a.商品号,名称,单价,描述from 订单信息表

21、as a,商品信息表 as bwhere 订单号=001 and b.商品号 = (select 商品号from 订单明细表where 订单号=001)3、 查找由供应商老大供应商的商品情况select 商品号,商品名,单价,规格,数量from 订单明细表where 生产商=老大4、 查找指定客户购买的商品的具体信息select 商品号,名称,单价,规格,描述from 商品信息表where 商品号=(select 商品号from 订单明细表where 单位=雷经文)7、 创建触发器,游标和存储过程 在订单明细表上建立触发器,实现在商品规格作出改变时,相应的订单明细信息也作出更正。 use 订单管理系统 go create trigger tri_商品信息更新 on 订单明细表 for update as if rowcount=0 return update 商品信息表 set 规格=(select 规格 from inserted) where 规格=(select 规格 from deleted) if error!=0 begin rollback return end return go在客户信息表建立游标,用游标和变量逐行输出客户姓名和联系方式declare name varchar(20),teleph

温馨提示

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

评论

0/150

提交评论