1、第一章 设计任务与规定目及意义:此小型餐饮业管理系统设计重要是为了以便管理,对于各个进出账目,支出和收入管理便于系统化,在每月汇总计算中分析运营趋势和餐馆发展方向进行一定规划。通过各个月赚钱进行对比,分析那种方式更适合餐馆有利运营和更好地服务顾客。实现对餐馆内部各种管理电子化、自动化,提高各个模块之间办公效率,为高质量餐馆服务提供保证。任务:1.可以实现对该系统进行管理人员权限限制;2.使餐馆可以及时并灵活对菜品品种其价位等进行管理;3.为餐馆提供从客户点餐到结算等一系列操作服务,使之能简朴易行、以便、 清晰地进行管理第二章 系统功能分析一功能需求:餐饮管理系统中重要涉及对如下几种管理:账单管
2、理,财务管理,订餐管理,菜品管理,系统管理。(1)系统管理:系统管理涉及顾客名和密码,重要用于顾客登陆界面登陆和查询。(2)账单管理:账单管理涉及账单号和餐台,每一种餐台相应一种一种账单号,通过餐台号记录来对相应餐台进行记账管理,即就是记录每一种餐台消费金额。账单管理是财务管理一种小分支,是服务于财务管理。(3)财务管理:涉及账单号,时间和账目。账目用于记录账单号消费金额及时间,以便用于结算和汇总。每日结算要通过对每个餐台号消费金额汇总来记录,然后由每日结算汇总得出每月结算。帐务系统功能完整性。一旦该系统正式运营,餐厅每日营业帐和所有往来客户帐务操作结算都将依托计算机,该系统面对当前餐饮业各种
3、复杂结算规定应具备很强应变能力。(4)订餐管理:订餐管理仅涉及单价。订餐管理是便于顾客订餐和账单管理时对各个菜品消费金额记录,这样便于账单管理和财务汇总。 (5)菜品管理:菜品管理涉及菜名,菜品类别和菜品品种。菜品管理便于顾客点菜和记录各个餐台消费记账,菜品品种也便于餐馆食材采购。二. 数据需求:账单管理中账单号是主键,每一种餐台相应一种账单号。财务管理中账单号是主键,每一种账单号均有相应时间和账目记录。订餐管理中单价就是主键。菜品管理中菜名是主键。系统管理中顾客名是主键。三. 性能需求:该餐饮系统操作简朴以便可适应各类中小型餐馆。第三章 系统功能模块设计一. 在该系统功能分析基本上,考虑Po
4、werBuilder程序编制特点,得到如下功能模块图。小型餐饮业管理系统系统管理账单管理订餐管理财务管理菜品管理顾客管理密码管理账单号管理餐台管理订单查询餐台点餐管理每日账目管理账目时间管理菜名管理菜品管理菜价管理类别管理图1 系统功能模块图二. 数据库设计1. 概念构造设计2. 逻辑构造设计3. 数据库实行 1) 数据库及表构造创立 设本系统使用数据库名为小型餐饮业管理系统,依照已设计关系模式及各模式完整性规定,当前就可以在SQL Server 6.x数据库系统中实现这些逻辑构造。下面是创立基本表SQL语句:/* = */* Table:CAIPINGL */* = */create tab
5、le CAIPINGL( CPGL_NAME char(20) not null, CPGL_DANJIA integer not null, CPGL_LEIBIE char(8) null , CPGL_PINGZHONG char(8) null , CPGL_DIANCAI integer null , constraint PK_CAIPINGL primary key (CPGL_NAME,CPGL_DANJIA)go/* = */* Table:XTGL */* = */create table XTGL( USERNAME char(20) not null, PASSWORD
6、 char(8) not null, constraint PK_XTGL primary key (USERNAME,PASSWORD)go/* = */* Table:ZHANGDAGL */* = */create table ZHANGDAGL( ZHANGDAN_NUMBER numeric not null, ZHANGDAN_CANTAI numeric null , CAI_ZHANGDAN_NUMBER numeric null , constraint PK_ZHANGDAGL primary key (ZHANGDAN_NUMBER)go/* = */* Index:RE
7、LATION_383_FK */* = */create index RELATION_383_FK on ZHANGDAGL (CAI_ZHANGDAN_NUMBER)go/* = */* Table:CAIWUGL */* = */create table CAIWUGL( ZHANGDAN_NUMBER numeric not null, CAIWU_TIME timestamp null , CAIWU_AMOUNT char(10) null , constraint PK_CAIWUGL primary key (ZHANGDAN_NUMBER)go/* = */* Table:D
8、INGCANGL */* = */create table DINGCANGL( ZHANGDAN_NUMBER numeric not null, DCGL_NAME char(20) not null, DCGL_DANJIA int not null, constraint PK_DINGCANGL primary key (ZHANGDAN_NUMBER,DCGL_NAME,DCGL_DANJIA)go/* = */* Index:RELATION_451_FK */* = */create index RELATION_451_FK on DINGCANGL (ZHANGDAN_NU
9、MBER)go建立有关触发器,执行级联删除* = */* Database name: MODEL_1 */* DBMS name: Microsoft SQL Server 6.x */* Created on: -1-21 18:15 */* = */* Insert trigger ti_caiwugl for table CAIWUGL */create trigger ti_caiwugl on CAIWUGL for insert asbegin declare numrows int, numnull int, errno int, errmsg varchar(255) sel
10、ect numrows = rowcount if numrows = 0 return /* Parent ZHANGDAGL must exist when inserting a child in CAIWUGL */ if update(ZHANGDAN_NUMBER) begin if (select count(*) from ZHANGDAGL t1,inserted t2 where t1.ZHANGDAN_NUMBER = t2.ZHANGDAN_NUMBER) != numrows begin select errno = 30002, errmsg = Parent do
11、es not exist in ZHANGDAGL. Cannot create child in CAIWUGL. goto error end end return/* Errors handling */error: raiserror errno errmsg rollback transactionendgo/* Update trigger tu_caiwugl for table CAIWUGL */create trigger tu_caiwugl on CAIWUGL for update asbegin declare numrows int, numnull int, e
12、rrno int, errmsg varchar(255) select numrows = rowcount if numrows = 0 return /* Parent ZHANGDAGL must exist when updating a child in CAIWUGL */ if update(ZHANGDAN_NUMBER) begin if (select count(*) from ZHANGDAGL t1,inserted t2 where t1.ZHANGDAN_NUMBER = t2.ZHANGDAN_NUMBER) != numrows begin select e
13、rrno = 30003, errmsg = ZHANGDAGL does not exist. Cannot modify child in CAIWUGL. goto error end end /* Modify parent code of CAIWUGL for all children in ZHANGDAGL */ if update(ZHANGDAN_NUMBER) begin update ZHANGDAGL set CAI_ZHANGDAN_NUMBER = i1.ZHANGDAN_NUMBER from ZHANGDAGL t2,inserted i1,deleted d
14、1 where t2.CAI_ZHANGDAN_NUMBER = d1.ZHANGDAN_NUMBER and (i1.ZHANGDAN_NUMBER != d1.ZHANGDAN_NUMBER) end return/* Errors handling */error: raiserror errno errmsg rollback transactionendgo/* Delete trigger td_caiwugl for table CAIWUGL */create trigger td_caiwugl on CAIWUGL for delete asbegin declare nu
15、mrows int, errno int, errmsg varchar(255) select numrows = rowcount if numrows = 0 return /* Delete all children in ZHANGDAGL */ delete ZHANGDAGL from ZHANGDAGL t2,deleted t1 where t2.CAI_ZHANGDAN_NUMBER = t1.ZHANGDAN_NUMBER return/* Errors handling */error: raiserror errno errmsg rollback transacti
16、onendgo/* Insert trigger ti_dingcangl for table DINGCANGL */create trigger ti_dingcangl on DINGCANGL for insert asbegin declare numrows int, numnull int, errno int, errmsg varchar(255) select numrows = rowcount if numrows = 0 return /* Parent ZHANGDAGL must exist when inserting a child in DINGCANGL
17、*/ if update(ZHANGDAN_NUMBER) begin if (select count(*) from ZHANGDAGL t1,inserted t2 where t1.ZHANGDAN_NUMBER = t2.ZHANGDAN_NUMBER) != numrows begin select errno = 30002, errmsg = Parent does not exist in ZHANGDAGL. Cannot create child in DINGCANGL. goto error end end return/* Errors handling */err
18、or: raiserror errno errmsg rollback transactionendgo/* Update trigger tu_dingcangl for table DINGCANGL */create trigger tu_dingcangl on DINGCANGL for update asbegin declare numrows int, numnull int, errno int, errmsg varchar(255) select numrows = rowcount if numrows = 0 return /* Parent ZHANGDAGL mu
19、st exist when updating a child in DINGCANGL */ if update(ZHANGDAN_NUMBER) begin if (select count(*) from ZHANGDAGL t1,inserted t2 where t1.ZHANGDAN_NUMBER = t2.ZHANGDAN_NUMBER) != numrows begin select errno = 30003, errmsg = ZHANGDAGL does not exist. Cannot modify child in DINGCANGL. goto error end
20、end return/* Errors handling */error: raiserror errno errmsg rollback transactionendgo/* Insert trigger ti_zhangdagl for table ZHANGDAGL */create trigger ti_zhangdagl on ZHANGDAGL for insert asbegin declare numrows int, numnull int, errno int, errmsg varchar(255) select numrows = rowcount if numrows
21、 = 0 return /* Parent CAIWUGL must exist when inserting a child in ZHANGDAGL */ if update(CAI_ZHANGDAN_NUMBER) begin select numnull = (select count(*) from inserted where CAI_ZHANGDAN_NUMBER is null) if numnull != numrows if (select count(*) from CAIWUGL t1,inserted t2 where t1.ZHANGDAN_NUMBER = t2.
22、CAI_ZHANGDAN_NUMBER) != numrows - numnull begin select errno = 30002, errmsg = Parent does not exist in CAIWUGL. Cannot create child in ZHANGDAGL. goto error end end return/* Errors handling */error: raiserror errno errmsg rollback transactionendgo/* Update trigger tu_zhangdagl for table ZHANGDAGL *
23、/create trigger tu_zhangdagl on ZHANGDAGL for update asbegin declare numrows int, numnull int, errno int, errmsg varchar(255) select numrows = rowcount if numrows = 0 return /* Parent CAIWUGL must exist when updating a child in ZHANGDAGL */ if update(CAI_ZHANGDAN_NUMBER) begin select numnull = (sele
24、ct count(*) from inserted where CAI_ZHANGDAN_NUMBER is null) if numnull != numrows if (select count(*) from CAIWUGL t1,inserted t2 where t1.ZHANGDAN_NUMBER = t2.CAI_ZHANGDAN_NUMBER) != numrows - numnull begin select errno = 30003, errmsg = CAIWUGL does not exist. Cannot modify child in ZHANGDAGL. go
25、to error end end /* Modify parent code of ZHANGDAGL for all children in CAIWUGL */ if update(ZHANGDAN_NUMBER) begin update CAIWUGL set ZHANGDAN_NUMBER = i1.ZHANGDAN_NUMBER from CAIWUGL t2,inserted i1,deleted d1 where t2.ZHANGDAN_NUMBER = d1.ZHANGDAN_NUMBER and (i1.ZHANGDAN_NUMBER != d1.ZHANGDAN_NUMB
26、ER) end /* Modify parent code of ZHANGDAGL for all children in DINGCANGL */ if update(ZHANGDAN_NUMBER) begin update DINGCANGL set ZHANGDAN_NUMBER = i1.ZHANGDAN_NUMBER from DINGCANGL t2,inserted i1,deleted d1 where t2.ZHANGDAN_NUMBER = d1.ZHANGDAN_NUMBER and (i1.ZHANGDAN_NUMBER != d1.ZHANGDAN_NUMBER)
27、 end return/* Errors handling */error: raiserror errno errmsg rollback transactionendgo/* Delete trigger td_zhangdagl for table ZHANGDAGL */create trigger td_zhangdagl on ZHANGDAGL for delete asbegin declare numrows int, errno int, errmsg varchar(255) select numrows = rowcount if numrows = 0 return
28、/* Delete all children in CAIWUGL */ delete CAIWUGL from CAIWUGL t2,deleted t1 where t2.ZHANGDAN_NUMBER = t1.ZHANGDAN_NUMBER /* Delete all children in DINGCANGL */ delete DINGCANGL from DINGCANGL t2,deleted t1 where t2.ZHANGDAN_NUMBER = t1.ZHANGDAN_NUMBER return/* Errors handling */error: raiserror
29、errno errmsg rollback transactionendgo2) 数据库前台设计 依照数据库设计,该餐饮业管理系统可以提成四个子模块: 订餐管理 依照客户点菜单,采用checkbox从已有菜品中选定菜品,并记录。 菜品管理 顾客可以依照餐馆现行状况动态管理菜品,可以对菜品进行品种、类别分类,并可以即时调节菜价;对菜品调节,如添加删除,会级联添加和删除订餐管理中菜单一栏中内容。 账单管理 顾客依照现餐馆内用餐状况对各餐台进行管理,同步可以查询客户点餐状况。 财务管理 记录餐馆营业状况,准时间、账单号进行管理,同步可用于客户结账。第四章 运营成果与测试一 系统运营1. 系统登录界面
30、 顾客输入已注册过顾客名和密码,非法顾客不得进入系统。2. 总系统界面 顾客依照需要对系统选取相应功能,进行模块化管理。3. 账单管理系统界面 一种账单号相应一种客户,通过账单号对各个客户消费进行管理,可进行添加删除操作,并可对各个客户消费状况进行查询。4. 订餐管理系统 顾客根据客户点菜单,以打勾方式,从右边菜单框中选取菜品输入到左边订餐框中,从而对客户消费进行记录。5. 菜品管理管理系统 顾客依照需要可即时调节菜品菜名、品种、类别、单价,同步可以进行查询当前菜品状况。6. 财务管理系统 记录各个客户消费时间(结账时间)、账单号、账目,以便日后进行财务记录,和核对;可进行添加、删除、查询操作。二 调试中浮现问题阐明与解决1. 在做订餐管理系统时,浮现订餐成果无法输入到数据库现象。经检查发现是主键设立浮现问题,修改后系统正常运营。2. 做账目管理系统时,时间属性无法输入,经检查,是在概念模型设立时所选取格式不当导致SQL语句生成浮现问题,修改后系统正常运营。参照资料:数据库原理与应用 作者:高荣芳PowerBuilder数据库开发技术 作者:陈佳友