管理信息系统实验报告设计.docx
《管理信息系统实验报告设计.docx》由会员分享,可在线阅读,更多相关《管理信息系统实验报告设计.docx(28页珍藏版)》请在冰豆网上搜索。
管理信息系统实验报告设计
交通与汽车工程学院
实验报告
课程名称:
课程代码:
年级/专业/班2009级物流管理物流班
学生姓名:
学号:
实验总成绩:
任课教师:
开课学院:
交通与汽车工程学院
实验中心名称:
计算机机房
目录
一、系统需求分析3
1.1问题的提出3
1.2可行性分析3
1.3系统的设计目标3
二、系统设计4
2.1系统设计4
2.2系统运行环境4
三、系统结构框架4
3.1系统结构框架4
3.2系统功能设计5
四、系统数据库设计6
4.1超市管理系统数据库E-R模型6
4.2数据库表设计6
4.3创建数据库8
五、操作模块9
5.1系统登录模块9
5.2商品信息管理模块10
5.3职工信息管理模块12
5.4供货商信息管理模块13
5.5添加销售信息模块15
5.6添加进货信息模块16
5.7库存信息管理模块19
5.8权限设置管理模块20
六、系统管理20
6.1身份验证20
6.2自动编号21
6.3设置文本框只能输入数字型字符串22
一、系统需求分析
随着人们生活水平的不断提高,对于物质的需求也越来越高,而超市作为日常生活用品聚集的场所,随着全球各种超市的数目的不断增加,规模不断增大,其管理难度也相应的增加,而为了适应当今信息化发展的时代,一套完整的超市商品管理系统显得尤为重要。
1.1问题的提出
在信息化高速发展的今天,超市商品管理的信息化管理已成为必不可缺的一部分,但是目前的大多数超市商品管理系统应用难度较高,许多工作需要技术人员配合才能完成,角色分工不明确;改版工作量大,系统扩展能力差,应用时更是降低了灵活性,这就使得一套完善的、能够正常工作的商品管理系统应运而生。
1.2可行性分析
系统的可行性分析是对课题的通盘考虑,是系统开发者进行进一步工作的前提,是系统设计与开发的前提与基础。
系统的可行性分析可以使系统开发者尽可能早的估计到课题开发过程中的困难,并在定义阶段认识到系统方案的缺陷,这样就能花费较少的时间和精力,也可以避免许多专业方面的困难。
所以,系统的可行性分析在整个开发过程中是非常重要的。
1.2.1经济可行性分析
因为通过网络传递销售信息可以不受距离的限制,因此可以借阅许多的人力和物力,方便管理,由此可以减少不必要的开支,同时该系统可以提高超市的销售效率,即提高了超市的经济效益,所以从经济上完全是可行的。
1.2.2技术可行性分析
本系统采用基于Windows的图形用户界面,而该系统是大家熟悉的操作系统,对于那些有一般的计算机知识的人员就可以轻松上手。
而整个超市管理系统采用最友好的交互界面,简介明了,不需要对数据库进行深入的了解。
综合以上三方面,该系统具有很高的开发可行性,无论是从技术上或者经济上还是操作上。
因此,可以设计该系统的数据流程图,建立数据字典。
1.3系统的设计目标
本系统主要包括四大模块,分别是人事管理模块,销售管理模块,进货管理模块,库存管理模块。
每个模块的功能如下:
1.人事管理模块功能:
(1)实现职工信息的查询;
(2)实现职工信息的更新,包括增加、删除、修改功能;
(3)实现供货商信息的查询;
(4)实现供货商信息的更新,包括增加、删除、修改功能。
2.销售管理模块功能:
(1)进行前台的销售;
(2)将前台的销售与后台的数据库联系起来。
3.进货管理模块功能:
(1)实现进货信息的查询;
(2)实现进货信息的更新,包括增加、删除、修改功能。
4.库存管理模块功能:
(1)实现商品库存信息的查询;
二、系统设计
2.1系统设计
通过权衡对各种编程语言和数据库使用的熟练程度,本系统选用MicrosoftVisualStudio2005作为前台开发工具,后台数据库采用SQLServer2005,整体设计以软件工程思想为指导思想,力求开发一个实用性强、操作简单且功能完整的超市商品管理系统。
2.2系统运行环境
客户端
操作系统:
WindowsNT/2000/XP或更高版本
服务器
操作系统:
WindowsXP
数据库:
MicrosoftSQLServer2005
前台:
MicrosoftVisualStudio2005
三、系统结构框架
3.1系统结构框架
一般的超市商品管理系统,主要由五大模块组成,即商品信息管理模块,人事管理模块,销售管理模块,进货管理模块,库存管理模块,此系统也不例外,主要有此五大模块组成。
图3-1系统功能结构图。
图3-1系统功能结构图
3.2系统功能设计
系统功能设计是使整个系统能基本实现超市的进、销、存等管理功能,能让超市管理者更直观的了解超市的经营状况,以做出相应的经营决策。
管理信息系统(MIS)就是要对这些资源建立正确的数据库,并进行信息的收集、传送、存储、编制成各种凭证、报表、台帐、图形等信息,同时对这些信息进行维护,通过实测超市的各种运行情况,并利用过去的历史数据预测未来的发展,从超市全局的角度出发进行决策,利用信息控制超市的行为,附注超市完成其目标。
本系统主要包括四大模块,分别是人事管理模块,销售管理模块,进货管理模块,库存管理模块。
每个模块的功能如下:
1.商品管理模块功能:
(1)实现商品信息的查询;
(2)实现职工信息的更新,包括增加、删除、修改功能;
2.人事管理模块功能:
(1)实现职工信息的查询;
(2)实现职工信息的更新,包括增加、删除、修改功能;
(3)实现供货商信息的查询;
(4)实现供货商信息的更新,包括增加、删除、修改功能。
3.销售管理模块功能:
(1)实现前台商品的销售;
(2)将商品的销售信息与数据库联系起来。
4.进货管理模块功能:
(1)实现进货信息的查询;
(2)实现进货信息的更新,包括增加、删除、修改功能。
5.库存管理模块功能:
(3)实现库存信息的查询;
四、系统数据库设计
4.1超市管理系统数据库E-R模型
通过对超市管理系统分析,得出系统的E-R图。
图5-1数据库E-R模型图。
图4-1数据库E-R模型图
4.2数据库表设计
4.2.1职工信息表
职工信息表(Staff-Bill)用于存储职工信息,职工编号为主键是唯一标识。
表中各字段功能定义如表4-2-1所示。
中文字段名
英文字段名
字段类型
长度
主键/外键
字段值约束
职工编号
StaffID
char
6
P
NOTNULL
姓名
name
marcher
8
F
NOTNULL
性别
sex
Nchar
2
NOTNULL
类别
kind
Novarchar
10
NULL
身份证号
IdCard
marcher
18
NOTNULL
备注
others
Ntext
50
NULL
表4-2-1职工信息表(Staff-Bill)
4.2.2用户登录表
用户登录表(Users-Info)用于存储用户的基本登录信息。
表中各字段功能定义如4-3所示。
中文字段名
英文字段名
字段类型
长度
主键/外键
字段值约束
账号
LoginID
char
6
P/F
NOTNULL
密码
PassWord
char
6
P
NOTNULL
表4-2-2用户信息表(Users-Info)
4.2.3商品信息表
商品信息表(Goods-Info)用于存储商品的信息。
表中各字段功能定义如表4-2-3所示。
中文字段名
英文字段名
字段类型
长度
主键/外键
字段值约束
商品编号
MarchID
char
6
P
NOTNULL
供货商号
ProfferID
char
6
F
NOTNULL
名称
FullName
Nvarchar
80
NOTNULL
类别
kind
Nvarchar
8
NULL
单价
UnitCost
money
4
NOTNULL
备注
others
Ntext
50
NULL
表4-2-3商品信息表(Goods-Info)
4.2.4供货商信息表
供货商信息表(Sup-Info)用于存储供货商的信息。
表中各字段功能定义如表4-2-4所示。
中文字段名
英文字段名
字段类型
长度
主键/外键
字段值约束
供货商号
SupplierID
char
6
P
NOTNULL
名称
Name
nvarchar
50
NOTNULL
联系人
contactPerson
nvarchar
8
NOTNULL
联系电话
phone
varchar
12
NOTNULL
联系地址
address
nvarchar
50
NOTNULL
备注
others
ntext
50
NULL
表4-2-4供货商信息表(SupInfo)进货信息表
4.2.5进货信息表
进货信息表(Buy)存储进货信息。
表中各字段功能定义如表4-2-5所示。
中文字段名
英文字段名
字段类型
长度
主键/外键
字段值约束
进货单号
BuyID
char
6
P
NOTNULL
商品编号
GoodsID
char
6
P/F
NOTNULL
供货商号
SupplierID
char
6
F
NOTNULL
进货价
Price
money
4
NOTNULL
数量
Amount
int
4
NOTNULL
金额
Sum
money
4
NOTNULL
进货日期
Date
datetime
8
NOTNULL
备注
Remark
ntext
50
NULL
表4-2-5进货信息表(Buy)
4.2.6销售信息表
销售信息表(Sell)用于存储销售信息。
表中各字段功能定义如表4-2-6所示。
中文字段名
英文字段名
字段类型
长度
主键/外键
字段值约束
销售单号
SeelID
char
6
P
NOTNULL
商品编号
GoodsID
char
6
P/F
NOTNULL
销售数量
Amount
int
4
NOTNULL
销售日期
Date
datetime
8
NOTNULL
表4-2-6销售信息表(Sell)
4.2.7库存信息表
库存信息表(Stock)存储库存信息。
表中各字段定义如表4-2-7所示。
中文字段名
英文字段名
字段类型
长度
主键/外键
字段值约束
商品编号
GoodsID
char
6
P/F
NOTNULL
库存数量
Amount
int
4
NOTNULL
表4-2-7库存信息表(Stock)
4.3创建数据库
(1)使用T—SQL语句创建超市商品管理系统数据库。
CREATEDATABASEdb_SMMSONPRIMARY
(NAME=N'db_SMMS',FILENAME=F:
\SMMS\SMMS\\DataBase\db_SMMS.mdf',SIZE=3072KB,FILEGROWTH=1024KB)
LOGON
(NAME=N'db_SMMS_log',FILENAME=N'F:
\SMMS\SMMS\DataBase\db_SMMS_log.ldf',SIZE=1024KB,FILEGROWTH=10%)
(2)使用T—SQL语句创建库存表。
CREATETABLEStock(GoodsID)
varchar(10)COLLATEChinese_PRC_CI_ASNOTNULL,
AmountintoNOTNULL,
PRIMARYKEY(StockID),
FOREIGNKEY(GoodsID)REFERENCEStb_Goods(GoodsID));
(3)使用T—SQL语句创建库存视图。
createviewv_StockS
AS
SELECTtb_Stock.StockID,tb_Goods.GoodsName,tb_Stock.Amount,tb_Stock.RemarkFROM
tb_StockINNERJOINtb_GoodsONtb_Stock.G
五、操作模块
5.1系统登录模块
主要实现代码如下:
publicboolVeri(stringtb_table,stringId,stringPwd)
{
DataClass.MyMeansMyClass=newSMMS.DataClass.MyMeans();
booljud=false;
if(Id!
=""&&Pwd!
="")
{
SqlDataReadertemDR=MyClass.getcom("select*from"+tb_table+"whereUserName='"+Id.Trim()+"'andPass='"+Pwd.Trim()+"'");
jud=temDR.Read();
if(jud)
{
DataClass.MyMeans.Login_Name=Id.Trim();
DataClass.MyMeans.Login_ID=temDR.GetString(0);
DataClass.MyMeans.My_con.Close();
DataClass.MyMeans.My_con.Dispose();
}
else
{
MessageBox.Show("用户名或密码错误!
","提示",MessageBoxButtons.OK,MessageBoxIcon.Information);
}//endif(jud)
MyClass.con_close();
}
else
{
MessageBox.Show("请将登录信息添写完整");
}
returnjud;
}//endpublicboolVeri()
用户登录模块在本系统的首页。
用户输入用户名和密码后,系统进行验证,验证通过进入程序的主界面。
界面如图5-1所示。
图5-1用户登录界面
5.2商品信息管理模块
此模块进行对商品信息的录入,能够对商品进行合理的管理,界面如图5-2所示。
图5-2商品信息管理界面
主要实现代码如下:
privatevoidbtnAdd_Click(objectsender,EventArgse)
{
boolt=false;
stringtxt;
stringRecID;
stringTypeID;
if(txtName.Text=="")
{
MessageBox.Show("请输入商品名称!
");
txtName.Focus();
}
elseif(txtPrice.Text=="")
{
MessageBox.Show("请输入商品单价!
");
txtPrice.Focus();
}
elseif(comboxType.Text=="")
{
MessageBox.Show("请选择商品类型!
");
comboxType.Focus();
}
elseif(txtKeep.Text=="")
{
MessageBox.Show("请输入保质期");
txtKeep.Focus();
}
else
{
txt=txtName.Text.Trim();
SqlDataReadertemDR=MyDataClass.getcom("select*fromtb_GoodswhereGoodsName='"+txt+"'");
t=temDR.Read();
if(t)
{
MessageBox.Show("此商品名称已存在!
");
txtName.Text="";
txtName.Focus();
}
else
{
stringFind_SQL2;
stringRecID2;
try
{
TypeID=My_Set.Tables[0].Rows[comboxType.SelectedIndex][0].ToString();
RecID=MyMC.GetAutocoding("tb_Goods","GoodsID");//获取编号
RecID2=MyMC.GetAutocoding("tb_Stock","StockID");//获取编号
Find_SQL="insertintotb_Goods(GoodsID,GoodsName,TypeID,Remark,Price,Keep)values('"+RecID
+"','"+txtName.Text+"','"+TypeID+"','"+txtRemark.Text+"',"+txtPrice.Text+","+txtKeep.Text+")";
Find_SQL2="insertintotb_Stock(StockId,GoodsID,Amount)values('"+RecID2+"','"+RecID+"',0)";
MyDataClass.getsqlcom(Find_SQL);
MyDataClass.getsqlcom(Find_SQL2);//向库存添加信息
MessageBox.Show("添加成功!
");
ListViewIteml=newListViewItem();
l.Text=txtName.Text;
l.SubItems.Add(comboxType.Text);
l.SubItems.Add(txtPrice.Text);
l.SubItems.Add(txtKeep.Text);
l.SubItems.Add(txtRemark.Text);
listView1.Items.Add(l);
btnCancle_Click(sender,e);
}
catch(Exceptionec)
{
MessageBox.Show(ec.Message);
MessageBox.Show("添加失败");
}
}
}
}
5.3职工信息管理模块
此模块有对职工的添加,修改,删除等功能,能够对用户进行合理的管理,界面如图5-3所示。
图5-3职工信息管理界面
主要实现代码如下:
privatevoidbtnSave_Click(objectsender,EventArgse)
{
stringRecID;
if(txtName.Text=="")
{
MessageBox.Show("请添加职工姓名!
");
txtName.Focus();
}
else
{
if(Jud==1)
{
RecID=MyMC.GetAutocoding("tb_Worker","WorkerID");//获取编号
Find_SQL="insertintotb_Worker(WorkerID,WorkerName,Remark)values('"+RecID+"','"+txtName.Text+"','"+txtRemark.Text+"')";
MyDataClass.getsqlcom(Find_SQL);
MessageBox.Show("添加成功!
");
InfLoad();
WinstateT();
}
if(Jud==2)
{
Find_SQL="updatetb_WorkersetWorkerName='"+txtName.Text+"',Remark='"+txtRemark.Text+"'whereWorkerID='"+txtWorkerID.Text+"'";
MyDataClass.getsqlcom(Find_SQL);
MessageBox.Show("修改成功!
");
InfLoad();
WinstateT();
}
}
}
5.4供货商信息管理模块
此模块有对供货商的添加,修改,删除等功能,能够对供货商进行合理的管理。
界面如图5-4所示。
图5-4供货商管理界面
主要实现代码如下:
privatevoidbtnSave_Click(objectsender,EventArgse)
{
boolt=false;
stringtxt;
stringRecID;
if(txtName.Text=="")
{
MessageBox.Show("请输入供货商名称!
");
txtName.Focus();
}
else
{
if(Jud==1)
{
txt=txtName.Text.Trim();
SqlDataReadertemDR=MyDataClass.getcom("select*fromtb_SupplierwhereSupplierName='"+txt+"'");
t=temDR.Read();
if(t)
{
MessageBox.Show("此供货商名称已存在!
");
txtName.Text="";
txtName.Focus();
}
else
{
RecID=MyMC.GetAutocoding("tb_Supplier","SupplierID");//获取编号
Find_SQL="insertintotb_supplier(SupplierID,SupplierName,Tel,Address,Remark)values('"+RecID
+"','"+txtName.Text+"','"+txtTel.Text+"','"+txtAddress.Text+"','"+txtRemark.Text+"')";
MyDataClass.getsqlcom(Find_SQL);
MessageBox.Show("添加成功!
");
I