资源描述
实训报告数据库技术课程设计仓库管理系统
数据库技术课程设计
题目: 仓库管理系统
姓名:
学号:
班级:
时间: 年 6 月 28 日
目 录
1. 需求分析 1
1.1仓库管理系统的功能分析 1
1.2仓库管理系统的功能图 2
2. 概念结构设计 3
3. 逻辑结构设计 5
4. 数据库设计 5
4.1数据库和各表的创立 6
4.1.1数据表结构设计 6
4.1.2创立数据表SQL脚本 7
4.1.3数据表快照 10
4.2系统功能实现 13
5. 设计总结 14
参考文献 15
仓库管理系统
摘要:仓库管理是与我们日常生活息息相关的问题,随着改革开放的不断深入,经济飞速的发展,企业要想生存、发展,要想在激烈的市场竞争中立于不败之地,没有现代化的管理是万万不行的,仓库管理的全面自动化、信息化则是其中极其重要的部分。仓库管理信息系统正是基于这样的需求背景下研制开发的。
本文按照软件工程思想和管理信息系统的开发步骤,设计并实现了一个仓库管理信息系统。以系统开发过程为主线,介绍了系统从需求分析,逻辑设计,总体设计,详细设计以及系统测试、实施各阶段的主要内容和成果,包括系统结构图、业务流程图、数据流程图、E-R模型、物理表实现及其关系、功能模块、界面设计等等。最后对实现系统的优缺点进行了分析,提出了今后进一步完善系统的方向和方法。
设计实现的管理系统能够正确有效地完成仓库管理的日常入库出库等工作,极大提高了管理工作的效率和正确性,并能够根据需求进行灵活的查询,完成数据查询等功能;系统与数据库管理系统结合,提供了功能较为强大的数据查询功能,防止了越权操作、误操作,;系统界面友好,操作简单,效率高易掌握。最后,该系统是典型的管理信息系统(MIS),其设计开发过程具有通用性,对类似工作的开展具有借鉴意义。
关键词:管理员;一般用户;进出货查询;修改;删除。
1. 需求分析
经过对武汉市部分超市仓库管理进行调研、分析开发本系统的目的在于代替手工管理、统计报表等工作,具体要求包括:
数据录入:录入商品信息、供货商信息、入库信息、出库信息等信息;
数据修改:修改商品信息、供货商信息、帐号等信息;
统计数据:统计仓库里面的商品的数量,种类;
数据查询:输入查询条件,就会得到想要的查询结果。
1.1仓库管理系统的功能分析
仓库管理系统的主要功能是:
1)业务处理
|- 出库登记
|- 入库登记
2)基本资料
|- 货品类别
|- 货品资料
|- 库存变动类型
|- 供货单资料
3)系统维护
|- 密码修改
|- 操作人员管理
|- 数据清理
4)统计报表
|- 货物入库报表
|- 货物出库报表
1.2仓库管理系统的功能图
根据以上需求分析,仓库管理系统功能如图1-1所示。
仓库管理系统
员工管理
进货管理
出货管理
密码管理
员工信息查询
删除员工信息
增加员工信息
员工信息修改
进货信息查询询
进货信息修改
进货信息增加
删除进货信息
出货信息查询
出货信息修改
出货信息增加
修改密码
重新登录
删除出货信息
2.概念结构设计
仓库管理信息系统能够划分的实体有:货物信息实体、货物入库记录信息实体、货物出库记录信息实体,用E-R图一一描述这些实体。
1)货物信息实体及属性E-R图如图2-1所示:
货物信息实体
货名
产品数量
生产商
货号
单价
2)货物入库记录信息实体及属性E-R图如图……
入库信息实体
入库日期
入库产品数量
货号
用户名
3)货物出库记录信息实体系统E-R图如图……
出库产品数量
出库时间
货号
出库库信息实体实体
4)总的信息实体E-R图:
用户名
m
登记查询
仓 库
入库
管 理
出库
货 物
货 物
管理员
实体
m
n
拥 有
生产商
提 货
m_pSet->AddNew();
UpdateData(true);
m_pSet->Update();
1
m_pSet->AddNew();
UpdateData(true);
m_pSet->Update();
1
m_et->AddNew();
UpdateData(true);
m_pSet->Update();
1
n_pSet->AddNew();
UpdateData(true);
m_pSet->Update();
1
m_pSet->AddNew();
UpdateData(true);
m_pSet->Update();
1
n
m_pSet->Update();
1
n
1
n
1
m
n
管理员
登记查询
1
经理
出货清单
3.逻辑结构设计
对仓库管理系统E-R图分析,结合各实体属性E-R图,考虑各图之间的关系,本系统的逻辑关系结构根据用户的要求设计该仓库管理系统共使用了四张表,分别是商品信息表(Goods)、进出货类型表(Record)、员工信息表(User1)以及用户登陆信息表(Users)。(说明:“#”表示主键,下划线表示外键)
E-R图转换成关系模式。
User1 (员工号#, 姓名, 密码, 住址, 性别, 电话)
Goods (货号#,货名,单价,生产数量,生产商)
Record (货号,日期,用户名#,进出货产品数量,管理员)
Users (用户名,密码#)
4.数据库设计
数据库管理系统选用SQL Server ,根据仓库管理系统的功能分析及逻辑关系模式在SQL Server中创立了一个名为“CKGL”的数据库,并在给数据库中一共创立了4张表,包括用户登录表、仓库数据表“Goods”、仓库出入信息表“Record”。在“Users”中包括2个字段,其中“用户名”字段用于存储用户注册及登陆的用户名;“密码”字段用于存储登陆的密码。在表“Goods”包括五个字段,其中“货号”字段用于存储货物的编号;“货名”字段用于存储货物的名称;“单价”字段用于存储货物的单价;“生产商”字段用于存储货物的生产商;“产品数量”字段用于存储货物的产品数量。在表“Record”中包括五个字段,其中,“日期”字段用于存储进出货日期;“货号”字段用于存储进出货货号;“产品数量”字段用于存储进出货产品数量;“用户名”字段用于存储进出货用户名;“进出货类型”字段用于存储进出货类型。在表“User1”中包括六个字段名,其中“员工号”字段用于存储员工工号;“姓名”字段用于存储员工姓名;“密码号”字段用于存储员工密码;“住址”字段用于存储员工住址;“性别”字段用于存储员工性别;“电话”字段用于存储员工电话。
4.1数据库和各表的创立
4.1.1数据表结构设计
1) 货物信息表:
序号
数据项名称
别名
数据类型
数据长度
1
货号
int
4
2
货名
char
50
3
单价
int
4
4
产品数量
int
200
5
生产商
char
100
2)货物出入库表:
序号
数据项名称
别名
数据类型
数据长度
1
货号
int
4
2
日期
datetime
50
3
进出货类型
char
4
4
产品数量
int
200
5
用户名
char
16
3)员工信息表:
序号
数据项名称
别名
数据类型
数据长度
1
员工号
int
2
姓名
char
8
3
密码
int
4
住址
char
30
5
性别
char
2
6
电话
Int
4.1.2创立数据表SQL脚本
create database CKGL
go
use CKGL
go
create table Users
(
用户名 char(16),
密码 int ,
用户类型 varchar(10)
)
go
insert into Users(用户名,密码,用户类型) values('Manager',123456,'System')
insert into Users(用户名,密码,用户类型) values('User',456789,'User')
go
create table User1
(
员工号 int ,
姓名 char(8),
密码 int references Users(密码),
住址 char(30),
性别 char(2),
电话 int
)
go
insert into User1(员工号,姓名,密码,住址,性别,电话)values(1001,'张三',123456,'湖北','男',1010110)
insert into User1(员工号,姓名,密码,住址,性别,电话)values(1002,'李四',123456,'湖北','男',1010120)
go
create table Goods
(
货号 int ,
货名 char(50),
单价 int,
生产商 char(100),
产品数量 int
)
go
insert into Goods(货号,货名,单价,生产商,产品数量)values(1,'红塔山香烟',10,'红塔山集团',200)
insert into Goods(货号,货名,单价,生产商,产品数量)values(2,'红星二锅头',3,'京酒厂',100)
insert into Goods(货号,货名,单价,生产商,产品数量)values(3,'六神花露水',4,'六神花露水厂',600)
go
create table Record
(
日期 datetime,
货号 int,
产品数量 int,
用户名 char(16),
进出货类型 char(4)
)
4.1.3数据表快照
上述脚本形成的表在SQL Server 中,如下图所:
各表间的关系图如图:
4.2系统功能实现
要实现需求分析中系统各功能,需要设计一些存储过程、触发器及相应的查询语句。…
1.添加仓库商品信息存储过程:
CREATE PROCEDURE 商品管理
@huohao int
AS
SELECT Goods.货号,货名,单价,生产商,产品数量
FROM Goods JION Recard ON Goods.货号=Recard.货号
WHERE 货号=@huohao
GO
2. 删除、更新仓库商品记录触发器:
CERATE TRIGGER CKGL ON Goods
FOR DELETE, UPDATE
AS
DECLARE @huohao int
SELECT @huohao=货号 FROM DELETE
SELETE @huohao=货号 FROM UPDATE
GO
5.设计总结
经过了这次仓库管理系统的课程设计我们团对从中学到了很多,同时明白了做一个小型软件的步骤和流程.如何让自己设计的软件运用到具体的实际工作中,这是一个关键的环节.还有就是程序设计和运行测试中遇到的问题该如何解决,从解决问题中我也学到了许多平时课本上所没有的知识.当然,能够完成这个仓库管理系统我们团队每个人很有成就感。
运用到的开发工具和软件技术:
此系统结合货物仓库管理的要求,对C#程序设计、SQL语言的学习和应用,主要完成货物仓库管理系统的需求分析,系统的数据库设计和实现,系统的表单设计,主控程序设计,并由此设计了数据库结构和应用程序。系统运行结果证明,我们团队设计的货物仓库管理系统基本能够满足仓库管理者完成仓库管理的日常工作,包括材料的入库,出库以及库存材料信息的管理维护等
软件还需要哪些改进:
在编写源程序代码的过程中对语言的运用还需要提高,应使写出来的程序更加简洁,易读懂,更加满足实际工作的需要.要想使做出来的程序更好的利用还需根据实际需要在今后的运用中不断的改进和完善。我们的仓库管理系统还是有很多的缺陷,有很多的漏洞,在实际运用方面还是有一些欠缺,其中的有些环节还不是很明确,不是很系统,只是一些编写技术的拼凑,因此离实际运用还是有一些距离。可是一些的基本功能我们还是实现了的,只是细节上还有不足,需要我们再进一步学习的基础上,再去完善,再去改进。
我们的管理系统其中还是有优点的,其中的职能体现和仓库管理中应该出现的管理功能都有实现,货物的进出管理,管理人员的管理都有很细的划分,代码的编写完全按照写程序的要求去写的,因此,代码的编写没有任何问题,只是精简程度上还不够,因此在这方面我们会去改进,我相信经过以后更加系统的学习,我们的仓库管理系统会运用到实际中去。
参考文献
[1] H.E.S.Said.T.Tan and K.Baker.Personal identification based on handwriting [J] .Pattern Recognition, 33:149-160, Jan.
[2] 王珊,萨师煊.数据库系统概论(第四版).北京:高等教育出版社, .5
[3] 高金兰.鲁立.数据库原理与SQL Server应用
[4] 张跃廷,苏宇,贯伟红。ASP.NET程序开发范例宝典
展开阅读全文