超市管理系统设计面向对象技术 大作业Word文档下载推荐.docx
《超市管理系统设计面向对象技术 大作业Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《超市管理系统设计面向对象技术 大作业Word文档下载推荐.docx(22页珍藏版)》请在冰豆网上搜索。
会员卡的有效期限为一年,满一年未续卡者,该会员卡将被注销。
✧安全性:
OS登陆、退出、换班与操作锁定等权限验证保护;
断电自动保护最大限度防止意外及恶意非法操作。
✧独立作业:
有的断网收银即在网络服务器断开或网络不通的情况下,收银机仍能正常作业
(2)、后台管理系统,本系统必须具备以下功能
✧进货管理:
根据销售情况及库存情况,自动制定进货计划(亦可手工制定修改),可以避免盲目进货造成商品积压。
按计划单有选择性地进行自动入库登记。
综合查询打印计划进货与入库记录及金额。
✧销售管理:
商品正常销售、促销与限量、限期及禁止销售控制。
综合查询各种销售明细记录、各地收银员收银记录以及交结账情况等。
按多种方式统计生成销售排行榜,灵活察看和打印商品销售日、月、年报表。
✧库存管理:
综合查询库存明细记录。
库存状态自动告警提示。
如库存过剩、少货、缺货等。
软件为您预警,避免库存商品积压损失和缺货。
库存自动盘点计算。
✧人员管理:
员工、会员、供货商、厂商等基本信息登记管理。
员工操作权限管理。
客户销售权限管理。
(3)系统结构
系统总体结构
模块子系统结构
功能描述:
商品录入子系统要求能快速录入商品,因此必须支持条形码扫描。
收银业务子系统能计算交易总额,打印交易清单,并根据会员卡打折。
进货管理子系统可以根据库存自动指定进货计划,进货时自动等级,以及提供查询和打印计划进货与入库记录的功能。
销售管理子系统可以控制某商品是否允许销售,查询每种商品的销售情况并产生年、月、日报表,同时可以生成销售排行榜。
库存管理子系统提供查询库存明细记录的基本功能,并根据库存的状态报警,以及自动盘点计算。
人员管理子系统提供基本信息登记管理,员工操作权限管理,客户销售权限管理的功能。
2.2、流程图
前台管理系统
顶层DFD图
第0层DFD图
第1层DFD图
2.3、户类型与职能
(1)、员工(营业员):
✧通过商品条形码扫描输入商品到购买清单
✧操作软件计算交易总金额
✧操作软件输出交易清单
✧对会员进行会员卡扫描以便打折
(2)、:
超市经理
✧操作软件录入商品,供货商,厂商
✧操作软件制定进货计划
✧查询打印计划进货与入库记录
✧操作软件控制商品销售与否
✧查询打印销售情况
✧操作软件生成销售排行榜
✧查询库存明细记录
✧根据软件发出的库存告警进行入货
✧操作软件进行盘点计算
(3)、总经理:
✧基本信息登记管理
✧员工操作权限管理
✧客户销售权限管理
2.4、统开发步骤
✧确定参与者和相关的用况
✧为每个用况设计过程
✧建立顺序图,确定每个脚本中对象的协作
✧创建类,确定脚本中的对象
✧设计,编码,测试,集成类
✧为过程编写系统测试案例
✧运行测试案例,检验系统
2.5、系统环境需求
✧系统模式
本系统采用C/S模式作为开发模式
✧硬件环境
服务器端:
高性能的计算机一台,
普通的双绞线作为连接。
客户端:
普通的计算机或者工作站,
普通的双绞线作为连接。
✧软件环境
安装SQLServer2000的服务器版本,
安装windows2000服务器版本,
配置了诺顿等必须的防毒软件。
客户端:
安装SQLServer2000的服务器版本,
安装了VB等可视化开发工具软件,
安装windows2000服务器版本。
3、系统概念设计
(1)、系统ER图
(2)、系统ER图说明
1)商店中的所有用户(员工)可以销售多种商品,每种商品可由不同用户(员工)销售;
2)每个顾客可以购买多种商品,不同商品可由不同顾客购买;
3)每个供货商可以供应多种不同商品,每种商品可由多个供应商供应。
(3)、视图设计
1)交易视图(v_Dealing)——用于查询交易情况的视图;
2)计划进货视图(v_PlanStock)——用于查询进货计划的视图;
3)销售视图(v_Sale)——用于查询销售明细记录的视图;
4)入库视图(v_Stock)——用于查询入库情况的视图。
4、逻辑设计
(1)、系统关系模型
a)商品信息表(商品编号,商品名称,价格,条形码,促销价格,促销起日期,促销止日期,允许打折,库存数量,库存报警数量,计划进货数,允许销售,厂商编号,供货商编号)
b)用户表(用户编号,用户名称,用户密码,用户类型)
c)会员表(会员编号,会员卡号,累积消费金额,注册日期)
d)销售表(销售编号,商品编号,销售数量,销售金额,销售日期)
e)交易表(交易编号,用户名称,交易金额,会员卡号,交易日期)
f)进货入库表(入库编号,入库商品编号,入库数量,单额,总额,入库日期,计划进货日期,入库状态)
g)供货商表(供货商编号,供货商名称,供货商地址,供货商电话)
h)厂商表(厂商编号,厂商名称,厂商地址,厂商电话)
(2)、系统数据库表结构
数据库表索引
表名
中文名
MerchInfo
商品信息表
User
用户表
Menber
会员表
Sale
销售表
Dealing
交易表
Stock
进货入库表
Provide
供货商表
Factory
厂商表
商品信息表(MerchInfo)
字段名
字段类型
长度
主/外键
字段值约束
对应中文名
MerchID
int
4
P
Notnull
商品编号
MerchName
Varchar
50
商品名称
MerchPrice
Money
价格
MerchNum
Int
库存数量
CautionNum
库存报警数量
PlanNum
null
计划进货数
BarCode
条形码
SalesProPrice
促销价格
SalesProDateS
Datetime
8
促销起日期
SalesProDateE
促销止日期
AllowAbate
允许打折
AllowSale
允许销售
FactoryID
10
F
厂商编号
ProvideID
供货商编号
用户表(User)
UserID
varchar
用户编号
UserName
25
用户名称
UserPW
用户密码
UserStyle
用户类型
会员表(Menber)
MemberID
会员编号
MemberCard
20
会员卡号
TotalCost
累积消费金额
RegDate
注册日期
销售表(Sale)
SaleID
销售编号
MerChID
SaleDate
销售日期
SaleNum
销售数量
SalePrice
销售单额
交易表(Dealing)
DealingID
交易编号
DealingPrice
交易金额
DealingDate
交易日期
入库纪录表(Stock)
StockID
入库编号
入库商品编号
入库数量
单额
TotalPrice
总额
StockDate
入库日期
PlanDate
计划进货日期
StockState
入库状态
供货商表(Provide)
ProvideName
供货商名称
ProvideAddress
250
供货商地址
ProvidePhone
供货商电话
厂商表(Provide)
FactoryName
厂商名称
FactoryAddress
厂商地址
FactoryPhone
厂商电话
5、源码
/*----------创建数据库----------*/
createdatabaseSuperMarketdb
onprimary
(
name=SuperMarketdb,
filename='
C:
\ProgramFiles\MicrosoftSQLServer\MSSQL\Data\SuperMarketdb.mdf'
size=100MB,
maxsize=200MB,
filegrowth=20MB
)
logon
name=SuperMarketlog,
\ProgramFiles\MicrosoftSQLServer\MSSQL\Data\SuperMarketdb.ldf'
size=60MB,
go
/*----------创建基本表----------*/
use[SuperMarketdb]
/*创建交易表*/
CREATETABLEDealing(
DealingIDintidentity(1,1)Primarykey,
DealingDatedatetimeNOTNULL,
DealingPricemoneyNOTNULL,
UserNamevarchar(25)NULL,
MemberCardvarchar(20)NULL
)
GO
/*创建厂商表*/
CREATETABLEFactory(
FactoryIDvarchar(10)Primarykey,
FactoryNamevarchar(50)NOTNULL,
FactoryAddressvarchar(250)NULL,
FactoryPhonevarchar(50)NULL
/*创建会员表*/
CREATETABLEMember(
MemberIDvarchar(10)Primarykey,
MemberCardvarchar(20)NOTNULL,
TotalCostmoneyNOTNULL,
RegDatedatetimeNOTNULL
/*创建商品信息表*/
CREATETABLEMerchInfo(
MerchIDintidentity(1,1)Primarykey,
MerchNamevarchar(50)UniqueNOTNULL,
MerchPricemoneyNOTNULL,
MerchNumintNOTNULL,
CautionNumintNOTNULL,
PlanNumintNOTNULL,
BarCodevarchar(20)UniqueNOTNULL,
SalesProPricemoneyNULL,
SalesProDateSdatetimeNULL,
SalesProDateEdatetimeNULL,
AllowAbateintNOTNULL,
AllowSaleintNOTNULL,
FactoryIDintNOTNULL,
ProvideIDintNOTNULL
/*创建供应商表*/
CREATETABLEProvide(
ProvideIDvarchar(10)Primarykey,
ProvideNamevarchar(50)NOTNULL,
ProvideAddressvarchar(250)NULL,
ProvidePhonevarchar(25)NULL
/*创建销售表*/
CREATETABLESale(
SaleIDintidentity(1,1)Primarykey,
MerChIDintNOTNULL,
SaleDatedatetimeNOTNULL,
SaleNumintNOTNULL,
SalePricemoneyNOTNULL
/*创建入库表*/
CREATETABLEStock(
StockIDintidentity(1,1)Primarykey,
MerchIDintNOTNULL,
MerchPricemoneyNULL,
TotalPricemoneyNULL,
PlanDatedatetimeNULL,
StockDatedatetimeNULL,
StockStateintNOTNULL
/*创建用户表*/
CREATETABLEUser(
UserIDvarchar(10)Primarykey,
UserNamevarchar(25)NOTNULL,
UserPWvarchar(50)NOTNULL,
UserStyleintNOTNULL,
/*----------创建表间约束----------*/
/*商品信息表中厂商编号、供应商编号分别与厂商表、供应商表之间的外键约束*/
ALTERTABLEMerchInfoADD
CONSTRAINT[FK_MerchInfo_Factory]FOREIGNKEY
(
[FactoryID]
)REFERENCESFactory(
),
CONSTRAINT[FK_MerchInfo_Provide]FOREIGNKEY
[ProvideID]
)REFERENCESProvide(
)
/*销售表中商品编号与商品信息表之间的外键约束*/
ALTERTABLESaleADD
CONSTRAINT[FK_Sale_MerchInfo]FOREIGNKEY
[MerChID]
)REFERENCESMerchInfo(
[MerchID]
)ONDELETECASCADE
/*入库表中商品编号与商品信息表之间的外键约束*/
ALTERTABLEStockADD
CONSTRAINT[FK_Stock_MerchInfo]FOREIGNKEY
/*----------创建索引----------*/
/*在交易表上建立一个以交易编号、交易日期为索引项的非聚集索引*/
CREATEnonclusteredINDEXIX_DealingONDealing(DealingID,DealingDate)
/*在商品信息表上建立一个以商品编号为索引项的非聚集索引*/
CREATEnonclusteredINDEXIX_MerchInfoONMerchInfo(MerchID)
/*在销售表上建立一个以销售编号、销售日期为索引项的非聚集索引*/
CREATEnonclusteredINDEXIX_SaleONSale(SaleID,SaleDate)
/*在入库表上建立一个以入库编号、入库日期、商品编号为索引项的非聚集索引*/
CREATEnonclusteredINDEXIX_StockONStock(StockID,StockDate,MerchID)
/*----------创建视图----------*/
/*创建用于查询交易情况的视图*/
CREATEVIEWv_Dealing
AS
SELECTDealingDateas交易日期,
UserNameas员工名称,
MemberCardas会员卡号,
DealingPriceas交易金额
FROMDealing
/*创建用于查询进货计划的视图*/
CREATEVIEWv_PlanStock
SELECTStock.StockIDasSID,
MerchInfo.MerchNameas商品名称,
MerchInfo.BarCodeas条形码,
Factory.FactoryNameas厂商,
Provide.ProvideNameas供货商,
Stock.MerchNumas计划进货数量,
Stock.PlanDateas计划进货日期
FROMStock,MerchInfo,Provide,Factory
WhereStock.MerchID=MerchInfo.MerchID
andProvide.ProvideID=MerchInfo.ProvideID
andFactory.FactoryID=MerchInfo.FactoryID
andStock.StockState=0
/*创建用于查询销售明细记录的视图*/
CREATEVIEWv_Sale
SELE