超市管理系统数据库设计.docx

上传人:b****8 文档编号:10152665 上传时间:2023-02-08 格式:DOCX 页数:25 大小:151.45KB
下载 相关 举报
超市管理系统数据库设计.docx_第1页
第1页 / 共25页
超市管理系统数据库设计.docx_第2页
第2页 / 共25页
超市管理系统数据库设计.docx_第3页
第3页 / 共25页
超市管理系统数据库设计.docx_第4页
第4页 / 共25页
超市管理系统数据库设计.docx_第5页
第5页 / 共25页
点击查看更多>>
下载资源
资源描述

超市管理系统数据库设计.docx

《超市管理系统数据库设计.docx》由会员分享,可在线阅读,更多相关《超市管理系统数据库设计.docx(25页珍藏版)》请在冰豆网上搜索。

超市管理系统数据库设计.docx

超市管理系统数据库设计

超市管理系统

1、项目计划

1.1系统开发目的

(1)大大提高超市的运作效率;

(2)通过全面的信息采集和处理,辅助提高超市的决策水平;

(3)使用本系统,可以迅速提升超市的管理水平,为降低经营成本,提高效益,增强超市扩张力,提供有效的技术保障。

1.2背景说明

21世纪,超市的竞争也进入到了一个全新的领域,竞争已不再是规模的竞争,而是技术的竞争、管理的竞争、人才的竞争。

技术的提升和管理的升级是超市业的竞争核心。

零售领域目前呈多元发展趋势,多种业态:

超市、仓储店、便利店、特许加盟店、专卖店、货仓等相互并存。

如何在激烈的竞争中扩大销售额、降低经营成本、扩大经营规模,成为超市营业者努力追求的目标。

1・3项目确立

针对超市的特点,为了帮助超市解决现在面临的问题,提高小型超市的竞争力,我们将开发以下系统:

前台POS销售系统、后台管理系统,其中这两个子系统又包含其它一些子功能。

1・4应用范围

本系统适应于各种小型的超市。

1・5定义

(1)商品条形码:

每种商品具有唯一的条形码,对于某些价格一样的商品,可以使用自定义条形码。

(2)交易清单:

包括交易的流水账号、每类商品的商品名、数量、该类商品的总金额、交易的时间、负责本次收银的员工号。

(3)商品积压:

在一定时期内,远无法完成销售计划的商品会造成积压。

(4)促销:

在一定时期内,某些商品会按低于原价的促销价格销售。

库存告警提示:

当商品的库存数量低于库存报警数量时发出提示。

(5)盘点:

计算出库存、销售额、盈利等经营指标。

2、逻辑分析与详细分析

2.1系统功能

(1)、零售前台(POS)管理系统,本系统必须具有以下功能:

商品录入:

根据超市业务特点制定相关功能,可以通过输入唯一编号、扫描条形码、商品名称等来实现精确或模糊的商品扫描录入。

该扫描录入方法可以充分保证各种电脑操作水平层次的人员均能准确快速地进行商品扫描录入。

收银业务:

通过扫描条形码或者直接输入商品名称(对于同类多件商品采用一次录

入加数量的方式)自动计算本次交易的总金额。

在顾客付款后,自动计算找零,同时打印交易清单(包括交易的流水账号、每类商品的商品名、数量、该类商品的总金额、交易的时间、负责本次收银的员工号)。

如果顾客是本店会员并持有本人会员卡,则在交易前先扫描会员卡,并对所购物品全部实行95折优惠,并将所购物

品的总金额累计到该会员的总消费金额中。

会员卡的有效期限为一年,满一年未

续卡者,该会员卡将被注销。

安全性:

OS登陆、退出、换班与操作锁定等权限验证保护;断电自动保护最大限

度防止意外及恶意非法操作。

独立作业:

有的断网收银即在网络服务器断开或网络不通的情况下,收银机仍能正

常作业

(2)、后台管理系统,本系统必须具备以下功能

进货管理:

根据销售情况及库存情况,自动制定进货计划(亦可手工制定修改),可以避免盲目进货造成商品积压。

按计划单有选择性地进行自动入库登记。

综合查询打印计划进货与入库记录及金额。

销售管理:

商品正常销售、促销与限量、限期及禁止销售控制。

综合查询各种销售明细记录、各地收银员收银记录以及交结账情况等。

按多种方式统计生成销售排行榜,灵活察看和打印商品销售日、月、年报表。

库存管理:

综合查询库存明细记录。

库存状态自动告警提示。

如库存过剩、少货、缺货等。

软件为您预警,避免库存商品积压损失和缺货。

库存自动盘点计算。

客户

人员管理:

员工、会员、供货商、厂商等基本信息登记管理。

员工操作权限管理

销售权限管理。

(3)系统结构

系统总体结构

小型超市零售管理系统

后台管理系统

模块子系统结构

 

功能描述:

商品录入子系统要求能快速录入商品,因此必须支持条形码扫描

收银业务

功能描述:

收银业务子系统能计算交易总额,打印交易清单,并根据会员卡打折。

功能描述:

进货管理子系统可以根据库存自动指定进货计划,进货时自动等级,以及提供查询和打印计划进货与入库记录的功能。

功能描述:

销售管理子系统可以控制某商品是否允许销售,查询每种商品的销售情况并产生年、月、日报表,同时可以生成销售排行榜。

功能描述:

库存管理子系统提供查询库存明细记录的基本功能,并根据库存的状态报警,以及自动盘点计算。

人员管理

基本信息登记管理

+员工操作权限管理

提一一八-

J客户销售权限管理

提示

 

文档

功能描述:

人员管理子系统提供基本信息登记管理,员工操作权限管理,客户销

售权限管理的功能。

2.2、流程图

前台管理系统

销售人员

第0层DFD图

第1层DFD图

2.3、户类型与职能

(1)、员工(营业员):

通过商品条形码扫描输入商品到购买清单操作软件计算交易总金额操作软件输出交易清单对会员进行会员卡扫描以便打折

(2)、:

超市经理

操作软件录入商品,供货商,厂商操作软件制定进货计划查询打印计划进货与入库记录操作软件控制商品销售与否查询打印销售情况操作软件生成销售排行榜查询库存明细记录

根据软件发出的库存告警进行入货操作软件进行盘点计算

(3)、总经理:

基本信息登记管理员工操作权限管理客户销售权限管理

2.4、统开发步骤

确定参与者和相关的用况为每个用况设计过程建立顺序图,确定每个脚本中对象的协作创建类,确定脚本中的对象设计,编码,测试,集成类为过程编写系统测试案例

运行测试案例,检验系统

2.5、系统环境需求

系统模式

本系统采用C/S模式作为开发模式

硬件环境

服务器端:

高性能的计算机一台,普通的双绞线作为连接。

客户端:

普通的计算机或者工作站,普通的双绞线作为连接。

软件环境

服务器端:

安装SQLServer2000的服务器版本,安装windows2000服务器版本,配置了诺顿等必须的防毒软件。

客户端:

安装SQLServer2000的服务器版本,安装了VB等可视化开发工具软件,安装windows2000服务器版本。

3、系统概念设计

(1)、系统ER图

供货商名称

供货商地址

供货商电话

供货商ID

厂商名称

厂商地址

厂商电话

厂商ID

消费

购买日期

消费金额

m

生产

累计金额

注册时间

会员ID

会员卡号

m

供货

供货日期

供货金额

允许销售

销售

销售

销售日期

价格

商品ID

商品名

商品

供货商

厂商

会员

(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)、系统数据库表结构

数据库表索引

表名

中文名

Merchlnfo

商品信息表

User

用户表

Menber

会员表

Sale

销售表

Dealing

交勿表

Stock

进货入库表

Provide

供货商表

Factory

厂商表

商品信息表(Merchlnfo)

字段名

字段类型

长度

主/外键

字段值约束

对应中文名

MerchlD

int

4

P

Notnull

商品编号

MerchName

Varchar

50

Notnull

商品名称

MerchPrice

Money

4

Notnull

价格

MerchNum

Int

4

Notnull

库存数量

CautionNum

Int

4

Notnull

库存报警数量

PlanNum

Int

4

null

计划进货数

BarCode

Varchar

50

Notnull

条形码

SalesProPrice

Money

4

促销价格

SalesProDateS

Datetime

8

促销起日期

SalesProDateE

Datetime

8

促销止日期

AllowAbate

Int

4

Notnull

允许打折

AllowSale

Int

4

Notnull

允许销售

FactoryID

Varchar

10

F

Notnull

厂商编号

ProvideID

Varchar

10

F

Notnull

供货商编号

用户表(User)

字段名

字段类型

长度

主/外键

字段值约束

对应中文名

UserID

varchar

10

P

Notnull

用户编号

UserName

Varchar

25

Notnull

用户名称

UserPW

Varchar

50

Notnull

用户密码

UserStyle

Int

4

Notnull

用户类型

会员表(Menber)

字段名

字段类型

长度

主/外键

字段值约束

对应中文名

MemberID

Varchar

10

P

Notnull

会员编号

MemberCard

Varchar

20

Notnull

会员卡号

TotalCost

Money

4

Notnull

累积消费金额

RegDate

Datetime

8

Notnull

注册日期

销售表(Sale)

字段名

字段类型

长度

主/外键

字段值约束

对应中文名

SaleID

Varchar

10

P

Notnull

销售编号

MerChID

Varchar

10

F

Notnull

商品编号

SaleDate

Datetime

8

Notnull

销售日期

SaleNum

Int

4

Notnull

销售数量

SalePrice

Money

4

Notnull

销售单额

交易表(Dealing)

字段名

字段类型

长度

主/外键字段值约束

对应中文名

DealingID

Varchar

10

P

Notnull

交勿编号

DealingPrice

Money

4

Notnull

交易金额

DealingDate

Money

4

Notnull

交易日期

MemberID

Varchar

10

会员卡号

UserName

Varchar

10

F

Notnull

用户名称

入库纪录表(Stock)

字段名

字段类型

长度

主/外键

字段值约束

对应中文名

StockID

Varchar

10

P

Notnull

入库编号

MerchID

Varchar

10

F

Notnull

入库商品编号

MerchNum

Int

4

Notnull

入库数量

MerchPrice

Money

4

Notnull

单额

TotalPrice

Money

4

Notnull

总额

StockDate

Datetime

8

Datetime

入库日期

PlanDate

Datetime

8

Datetime

计划进货日期

StockState

Int

4

Notnull

入库状态

供货商表(Provide)

字段名

字段类型

长度

主/外键

字段值约束

对应中文名

ProvideID

varchar

10

P

Notnull

供货商编号

ProvideName

Varchar

50

Notnull

供货商名称

ProvideAddress

Varchar

250

供货商地址

ProvidePhone

Varchar

25

供货商电话

厂商表(Provide)

字段名

字段类型

长度

主/外键

字段值约束

对应中文名

FactoryID

varchar

10

P

Notnull

厂商编号

FactoryName

Varchar

50

Notnull

厂商名称

FactoryAddress

Varchar

250

厂商地址

FactoryPhone

Varchar

25

厂商电话

5、源码

/*创建数据库*/

createdatabaseSuperMarketdb

onprimary

name=SuperMarketdb,

filename='C:

\ProgramFiles\MicrosoftSQLServer\MSSQL\Data\SuperMarketdb.mdf,size=100MB,

maxsize=200MB,

filegrowth=20MB

logon

name=SuperMarketlog,

filename='C:

\ProgramFiles\MicrosoftSQLServer\MSSQL\Data\SuperMarketdb.ldf,

size=60MB,

maxsize=200MB,

filegrowth=20MB

go

/*创建基本表*/

use[SuperMarketdb]

go

/*创建交易表*/

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

GO

/*创建会员表*/

CREATETABLEMember(

MemberIDvarchar(10)Primarykey,

MemberCardvarchar(20)NOTNULL,

TotalCostmoneyNOTNULL,

RegDatedatetimeNOTNULL

GO

/*创建商品信息表*/

CREATETABLEMerchInfo(

MerchIDintidentity(1,1)Primarykey,

MerchNamevarchar(50)UniqueNOTNULL,MerchPricemoneyNOTNULL,

MerchNumintNOTNULL,

CautionNumintNOTNULL,

PlanNumintNOTNULL,

BarCodevarchar(20)UniqueNOTNULL,SalesProPricemoneyNULL,SalesProDateSdatetimeNULL,SalesProDateEdatetimeNULL,AllowAbateintNOTNULL,

AllowSaleintNOTNULL,

FactoryIDintNOTNULL,

ProvideIDintNOTNULL

GO

/*创建供应商表*/

CREATETABLEProvide(

ProvideIDvarchar(10)Primarykey,ProvideNamevarchar(50)NOTNULL,ProvideAddressvarchar(250)NULL,ProvidePhonevarchar(25)NULL

GO

/*创建销售表*/

CREATETABLESale(

SaleIDintidentity(1,1)Primarykey,MerChIDintNOTNULL,

SaleDatedatetimeNOTNULL,

SaleNumintNOTNULL,SalePricemoneyNOTNULL

GO

/*创建入库表*/

CREATETABLEStock(

StockIDintidentity(1,1)Primarykey,MerchIDintNOTNULL,

MerchNumintNOTNULL,MerchPricemoneyNULL,TotalPricemoneyNULL,PlanDatedatetimeNULL,StockDatedatetimeNULL,StockStateintNOTNULL

GO

/*创建用户表*/

CREATETABLEUser(

UserIDvarchar(IO)Primarykey,UserNamevarchar(25)NOTNULL,UserPWvarchar(50)NOTNULL,UserStyleintNOTNULL,

GO

/*创建表间约束*/

/*商品信息表中厂商编号、供应商编号分别与厂商表、供应商表之间的外键约束*/

ALTERTABLEMerchInfoADD

CONSTRAINT[FK_Merchlnfo_Factory]FOREIGNKEY

[FactoryID]

)REFERENCESFactory(

[FactoryID]

),

CONSTRAINT[FK_MerchInfo_Provide]FOREIGNKEY

[ProvideID]

)REFERENCESProvide(

[ProvideID]

GO

/*销售表中商品编号与商品信息表之间的外键约束*/

ALTERTABLESaleADD

CONSTRAINT[FK_Sale_Merchlnfo]FOREIGNKEY

[MerChID]

)REFERENCESMerchInfo(

[MerchID]

)ONDELETECASCADE

GO

/*入库表中商品编号与商品信息表之间的外键约束*/

ALTERTABLEStockADD

CONSTRAINT[FK_Stock_MerchInfo]FOREIGNKEY

[MerchID]

)REFERENCESMerchInfo(

[MerchID]

)ONDELETECASCADE

GO

/*创建索引*/

/*在交易表上建立一个以交易编号、交易日期为索引项的非聚集索引*/

CREATEnonclusteredINDEXIX_DealingONDealing(DealingID,DealingDate)

GO

/*在商品信息表上建立一个以商品编号为索引项的非聚集索引*/

CREATEnonclusteredINDEXIX_MerchlnfoONMerchInfo(MerchlD)

GO

/*在销售表上建立一个以销售编号、销售日期为索引项的非聚集索引*/

CREATEnonclusteredINDEXIX_SaleONSale(SalelD,SaleDate)

GO

/*在入库表上建立一个以入库编号、入库日期、商品编号为索引项的非聚集索引*/

CREATEnonclusteredINDEXIX_StockONStock(StocklD,StockDate,MerchID)GO

/*创建视图*/

/*创建用于查询交易情况的视图*/

AS

SELECTDealingDateas交易日期,UserNameas员工名称,

MemberCardas会员卡号,

DealingPriceas交易金额

FROMDealing

GO

/*创建用于查询进货计划的视图*/

CREATEVIEWv_PlanStock

AS

SELECTStock.StockIDasSID,

MerchInfo.MerchNameas商品名称,

MerchInfo.BarCodeas条形码,

Factory.FactoryNameas厂商,

Provide.ProvideNameas供货商,

Stock.MerchNumas计划进货数量,

Stock.PlanDateas计划进货日期

FROMStock,MerchInfo,Provide,Factory

WhereStock.MerchID=MerchInfo.MerchlD

andProvide.ProvideID=MerchInfo.ProvidelDandFactory.FactoryID=MerchInfo.FactorylDandStock.StockState=0

GO

/*创建用于查询销售明细记录的视图*/

CREATEVIEWv_Sale

AS

SELECTMerchlnfo.MerchNameas商品名称,

MerchInfo.BarCodeas

条形码,

Merch

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 工程科技 > 能源化工

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1