《《餐饮服务系统--数据库的实现》.doc》由会员分享,可在线阅读,更多相关《《餐饮服务系统--数据库的实现》.doc(24页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、餐饮服务系统 -数据库的实现【摘要】在餐饮服务系统开发过程中,开发过程主要包括系统设计、前端应用程序的开发、后台的数据库设计。其中后台数据库设计中的关系数据库是相当重要的一块,它决定了我们整个系统的开发成败。从平台方面来说,我们采用了Microsoft公司的visual 作为开发工具,而数据库则是采用Microsoft SQL Server 2000作为开发环境。数据库的实现是系统设计时的重中之重,如果一个好的系统没有一个好的数据库就形同虚设,系统中采用了最新的数据访问技术ADO.net来实现对数据库的访问和实现系统的所有功能,虽然有效的解决了实际问题,简化了用户的操作,基本上满足了用户的需求
2、,且具有良好的可扩充性。但由于该系统的出发点局限于单机版,而且没有提供相应的Wed支持,所以给整个系统带来了一定的限制。关键词:数据库的实现;ER图;关系图;数据表;需求分析Abstract:In the dining service system, its main development process includes the database design of the development, backstage that the system design, head applies the procedure.Because the datas all keep in the d
3、atabase of, and the access that it passes to limit to authorize not, forbid the illegal interview and modify etc. operation with the accuracy and safeties of the assurance system, so say that the backstage database design is the whole system development process in very important one wreath, it comes
4、 to a decision the development success or failure of our whole system.This text mainly carries on something to elaborate from some basic designs of the database.For example database in stipulation of integrity of design, E- R diagram, the relation diagram, the data form of the data form etc. a few a
5、spect, these are all the foundation knowledge that the database carries out the mile.In view of the terrace aspect, the system is the visual conduct and actions development tool that adopted the company of Microsoft, but the database then adopts 2000 conduct and actions development environments of t
6、he Microsoft SQL Server.This system uses the latest data interview technique ADO.net to carry out the interview to the database and carry out all functions of the system, although resolved the actual problem effectively, simplifying the operation of the customer, satisfying the need of the customer
7、basically, have good can enlarge sex.But limit at the single machine version because of the point of departure of that system, and did not provide the homologous support of Wed, so brought certain restrict for the whole system.Keyword:The realization of the database;E- R diagram;Relate to the diagra
8、m;Data form;The need analysis; The integrity control目录引言3第一章系统功能简介3系统实现的功能3系统功能模块的划分3餐饮服务系统的内部结构4餐饮服务系统的权限4餐饮服务系统的流程4第二章数据库设计5需求分析与实体联系(ER)模型5数据表的建立8关系图11第三章餐饮系统中数据表格的实体完整性12实体完整性(Entity Integrity)12参照完整性(Referential Integrity)13用户自定义完整性(User-defined Integrity)14第四章 餐饮系统中数据库的基本操作15基本概念15INSERT 语句15S
9、ELECT语句16UPDATE语句18DELETE语句20第五章结论21参考文献22致谢23引言随着当今社会经济的快速发展,如今的餐饮服务业是越来越红火,同时在餐饮服务内部和正常营业业务以及扩展业务等方面也面临各种各样的挑战。首先,人员的管理、前台服务、后台支撑、预订服务等都需要大量的人力和物力;其次,餐饮服务业有其自身的特点,例如流动数据量大,而这些数据需要一定的保密性和商业安全性,为防止操作员或其他人员篡改和造假,“权限”设置是不可少的,然而计算机系统就是一个很好的工具;最后,餐饮服务已从原始的独家单户经营方式逐渐融合到了集食宿、旅游、购物、观光为一体的连锁服务大体系架构,管理的健全急需I
10、nternet技术的支持。随着当今社会经济的发展,对效率的要求也越来越高,因此利用计算机进行智能管理已日渐成为现在的趋势,也将成为现代社会各个部门进行管理的一个重要环节。那么开发一个完整的、操作简便的、界面友好的餐饮服务系统是势在必行。 中国自古以来就有“酒香不怕巷子深”、“精打细算”等经营之道,餐厅经营似乎不需要现代化,然而随着近几年的计算机技术的飞速发展和电脑软件技术应用的普及,已有人注意到了餐饮服务业这一市场领域,并致力于餐饮服务业的电算化,以提高工作效率。然而我们所设计的餐饮服务系统与传统的管理方式相比具有以下优势: (1)更有利于餐饮服务部门提高服务质量,减少物力财力; (2)使得管
11、理具有科学化、标准化、规范化; (3)提高了信息的准确性。 第一章系统功能简介系统实现的功能根据需求分析,系统要实现的功能如下:l 前台营业的管理(资源查询、点菜、结账)l 预定服务的管理(预定订单、预定订单查询)l 外卖服务的管理(外卖订单、外卖订单查询)l 系统管理(用户管理、修改密码)l 员工管理l 菜谱管理l 会员管理l 账单管理系统功能模块的划分由餐饮服务系统所要实现的功能需求,可以将整个系统的功能模块划分为以下个模块:1) 系统管理和业务授权模块:在该模块中实现了三级授权模式和对业务授权与系统管理分开授权的模式,是目前所有C/S程序中最常用的业务授权和系统管理的设计模式。具有在技术
12、上成熟、在实际中切合实际需求的模式。2) 餐饮服务营业模块:在该模块中首先对前台的餐饮服务进行对象的抽象化,并建立数学模型,分析数据流程,并对数据对象进行数据抽象、创建数据库,以及为前台营业的餐饮服务创建完整的定制服务合理收费数据处理的数据流程。3) 预定服务模块:为实现外饮服务的可扩展性所以增加了该模块,用户可以通过电话进行预定服务。(由于该系统是单机版,所以没有互联网服务)4) 外卖服务模块:为了切合实际需求,用户可以通过电话系统进行电话定购并要求送货上门的外卖服务,如提供盒饭等。5) 员工管理模块:主要是为了实现单位内部的员工管理。餐饮服务系统的内部结构所设计的餐饮服务系统是以实现餐饮服
13、务内部和正常营业业务以及扩展业务的自动化电算管理为核心。整个系统中个基本模块组成,其数据流程和内部结构如下图所示:前台营业 员工管理预定服务 外卖服务数据库 SQL消费单据员工信息外卖订单订单数据 用户管理权限分配 图1-1餐饮服务系统的权限对于餐饮服务业来说,其财务数据属于国家财务审计的对象之一,因此财务数据需要严格的保密性和高度的安全性。为了防止操作员或者其他人员对财务数据的篡改和造假账以逃税漏税等违法行为,必须对整个系统的数据管理进行严格的权限限制,防止越权行为。从系统的内部结构和数据流程来分析,以及参考软件业务授权的相关知识,可以将权限分解为两大类,即业务授权和人员授权。所谓的人员授权
14、就是对使用软件的人员进行权限的分配,而业务授权就是需要对员工所操作的模块进行进一步授权。在本系统中,用户的权限有四种,如表1-1所示:身 份标 识授 权 模 块系统管理员Administrator修改密码,用户管理(授权),数据库备份、压缩、恢复。经 理GeneralManager除数据库备份、压缩、恢复以外的所有功能模块部门管理员PartmentManager员工管理,资源(餐桌)管理,会员管理业务操作员ClientOperator前台营业服务或者预定酒宴服务或者扩展外卖服务表1-1餐饮服务系统的流程餐饮服务系统的流程如下所示:第一步:登录成功进入主界面(若登录失败,则返回重新登录)。第二步
15、:对主界面中的菜单进行操作。登录登录失败登录成功进入主界面前台营业预定服务外卖服务员工管理系统管理修改密码用户管理系统登录外卖查询外卖订单订单查询预定订单结账点菜菜单菜谱管理资源浏览用户图1-2第二章数据库设计本程序采用Microsoft SQL Server 2000作为数据库的开发环境。因为Microsoft SQL Server是一种基于客房机/服务器的关系型数据库管理系统,它使用TransactSQL语言在服务器和客户机之间传送请求。它有图形化用户界面,使系统管理和数据库管理更加直观、简单。提供了丰富的编程接口工具,可以让用户在进行程序设计时有更大的选择余地。它还支持Wed技术,使用户
16、能够很容易地将数据库中的数据发布到Wed页面上。可以说SQL Server是一个综合的、通用的、功能极强的关系数据库语言,它包括数据定义、数据操纵、数据管理、存取保护和处理控制等多种功能、。利用表(table)、索引(index)、关键字(keys)、行(rows)和列(columns)等来确定存储位置。所以基于对以上情况的考虑,我们选用了Microsoft SQL Server2000 作为我们的数据库开发环境。设计的重点在于如何能更方便地使各表、各数据之间能够有机地组合在一起,怎样设计更便于扩充。需求分析与实体联系(ER)模型由于ER模型与人们认识现实世界的相似性,因此在描述数据库的概念结
17、构或全局逻辑结构时,采用ER图这种图形化的表示很有好处。由于图形化的表示方法具有简单性、清晰性,这就是ER模型在进行数据库的概念模式设计时被广泛使用的重要原因。ER模型它决定着数据库的总体逻辑结构,这就要求我们在分析系统的时候要与用户进行交流、讨论,在尽量满足用户需求的情况下才能进入下一阶段的设计工作。在我们所设计的餐饮服务系统中,由于所要设计的系统中实现的功能要涉及前台营业的管理(资源查询、点菜、结账)、预定服务的管理(预定订单、预定订单查询)、外卖服务的管理(外卖订单、外卖订单查询)、系统管理(用户管理、修改密码)、员工管理、 菜谱管理、会员管理几个方面,所以数据库模型的设计主要是围绕着这
18、几个功能来展开的。根据用户的需求,我们可以进行数据库ER图的设计如下图:ConsumesummaryOrderInfoTablenumShippedaddressroomnameShippeddateOrderdateexcutedateOrderstyelIs checkedOrderidquantityunitpriceorderdatecustomerinfoIdentyLogindatecustomeridcustome_OrderItemsOrderInfo_ OrderItemsBook_OrderItemsOrderstyleOrderid TelephoneBookInfoEx
19、cutedateOrderdateAddressRelatorRoomnameTableInfoTablenumRoomnamepersonsStatusMenuInfoMenu_priceMenu_idMenu_styleMenu_discountMenu_materialMenu_saporMenu_descriptionMenu_pictureOrderItemsmenuidtablenumCustomeridMenu_orderitemsTable_orderitemsComsumercountBillInfoTablenumRoomNameBillIDTotalPriceSysDat
20、eBill_ OrderItemsMenu_nameOrderidContents 图2-1数据表的建立ER模型和关系模型都是现实世界抽象的逻辑表示。由于两种模型采用类似的设计原则,因此可以将ER设计转换为关系设计,而将数据库的表示从ER图转换为表的形式是由ER图产生关系数据库设计的基础。所以说数据表的建立过程就是将ER模型转换为关系模型的过程。所谓的关系模型就是指用二维表的集合来表示数据和数据间的联系。在建立数据表之前,我们先建立一个用来保存数据表的数据库FoodServer。在建立数据库之后就是建立数据表了。仍而我们知道数据库的ER模型可以表示为一些表的集合。ER模型中的每个实体集和联系都
21、有惟一的表与之对应,表名即为相应的实体集或联系集的名称。每个表有多个列,每列有惟一的列名。下面就是具体的数据表设计:用户信息表UserInfo在系统管理中,主要是涉及对用户信息表的设计。对于用户信息表的设计主要是从这几个方面来分析的:首先是用户信息表的主码(主键)的设计即用户号;其次是用户的密码、权限和身份的设计;再一个是为了提高界面的美观性,所以我们在设计用户信息表时还添加了一个用户像片属性。以下就是对用户信息表UserInfo的参数设计:字 段 名 称数 据 类 型长 度说 明User_id char15(主键)用户号User_pwdChar64密码User_pepdomSmallint2
22、用户身份User_modBit20用户模式User_pictureNvarchar255用户像片表2-1饭桌信息表TableInfo为了实现对饭桌的一些基本信息进行管理,让前台的操作员可以快速的查看饭桌的使用资源情况,如饭桌是不是处于空闲状态、可以供几个人使、它属于哪个房间等。我们把饭桌的一些基本信息做了如下设计:字 段 名 称数 据 类 型长 度说 明TablenumInt4(主键)桌号personsSmallint2使用人数Status varchar50使用状态Roomnamevarchar50房间号表2-2菜谱信息表MenuInfo以下这个表的设计主要是为了实现对菜谱的一些简单介绍,为
23、客户提供方便,而且还可以提高餐饮部门的工作效率,这也是前台营业管理的一个重要部分。具体的参数设计如下表所示:字段名称数据类型长度说明Menu_id Nvarchar16(主键)菜谱编号Menu_nameNvarchar50菜名Menu_priceDecimal9菜的价格Menu_discountFloat8优惠折扣Menu_styleNvarchar20菜谱类型Menu_saporNvarchar20地方风味Menu_descriptionNvarchar1000菜的描述Menu_materialNvarchar2000菜的材料Menu_pictureNvarchar100菜的图片表2-3订单
24、元素表OrderItems这个表涉及到前台营业的管理与预定订单的管理、外卖订单的管理等多个表,主它要的功能是进行多个表的连接,以便于查询。下表就是我们设计的订单元素表OrderItems:字段名称数据类型长度说明Orderiduniqueid16订单号menuiduniqueid16菜单号Customerid uniqueid16会员号tablenumInt 4桌号Roomname varchar50房间名orderdatedatetime8消费日期quantityint4数量unitpricemoney8单价表2-4预定订单信息表OrderInfo由于考虑到客户需要在某个时间内到餐馆进餐,如
25、一些大型的酒宴,这些就要提前预定好餐馆,基于这个因素,我们对预定订单的信息表进行了如下的设计:字段名称数据类型长度说明OrderidUniqueid16(主键)订单号OrderstyelSmallint2订单类型excutedateDatetime8执行时间OrderdateDatetime8预定时间ShippeddateDatetime8外送时间ShippedaddressNvarchar255外送地址Is checkedBit 1是否已确认roomnamevarchar50房间名Tablenum int4桌号表2-5员工信息表ClerkInfo员工是一个餐饮部门的工作人员,对于一个部门里的
26、职工,我们必须掌握它的一些基本情况,如员工的名字、性别、职别等内容,所以进行员工的管理是十分必要的。只有通过这些详细的内容,我们才可以对员工进行管理。下表是对员工信息表ClerkInfo参数的具体设计:字 段 名 称数 据 类 型长 度说 明ClerkID char18(主键)员工号ClerkName Nvarchar50员工名字Sex Bit1性别Marry Smallint2婚否Dept Nvarchar50部门Duty Nvarchar50职别Salary money8薪水HireDate Datetime8聘用日期Tel Nvarchar50电话photoPathNvarchar100
27、像片Address Nvarchar255地址表2-6会员信息表CustomerInfo会员管理是对入会人员的一些折扣上的信息处理,它也是属于前台营业管理中的一个特殊管理范畴。在进行结帐时,我们可以查看他是不是属于会员,如果是会员,那么我们可以在消费时进行规定范围内的打折活动。所以会员信息表的设计主要是包括会员号、身份证号、消费总金额、消费总次数、优惠折扣值、注册时日期。具体的参数设计如下:字段名称数据类型长度说明customerid uniqueid16(主键)会员号IdentyChar18身份证号ConsumesummaryMoney8消费总金额ComsumercountInt4消费总次数
28、DiscountratioReal4优惠折扣值LogindateDatetime8注册时日期表2-7外卖订单信息表BookInfo为了扩展餐饮业务,设计时也把外卖算在餐饮服务业里面。这样我们才可以拓展餐饮业务,加大经济来源。所以这个外卖也涉及到数据库中的表,以下就是对外卖订单的详细参数设计:字段名称数据类型长度说明Orderid uniqueid16(主键)订单号Orderstyle Smallint 2订单类型Orderdate Datetime 8预定时间Excutedate varchar8执行时间Relator varchar50订单联系人Telephone varchar50联系电话
29、Address varchar255外送地址Contents varchar255订单内容表2-8账单信息表BillInfo这个表所涉及的是消费者的一些基本信息,比如消费者的桌号、房间号、时间、总价等一些基本信息,只有这些信息正确,才是用户的真正的消费账单,消费者所花费的金额也是用这个账单信息表来进行计算的。下表所示就是账单信息表的参数设计:字段名称数据类型长 度说 明BillIDuniqueidentifier16(主键)账单号TableNumint4桌号RoomNamevarchar50房间号SysDatedatetime8时间TotalPricemoney8总价表2-9关系图在建立了关系
30、模型(数据表)以后,接下来的工作就是把关系模型转化成某个数据库管理系统所支持的数据模型,然后才能建立用户所需要的数据库。而在这个我们所设计的系统中我们所采用的是关系型的数据库,所以在这里我们必须把图转化为关系图。那么要怎样才能把图转化为关系图呢?针对 ER图中的每个实体、实体的每个属性以及每个联系集进行分析,就其对应的关系还有主属性用表的形式进行标识,把相对应的每一张表都进行严格意义上的定义。紧接着的就是如何进行表与表之间的连接(联系)。首先是分析各表之间的联系是属于哪一种;是一对多、多对一、多对多;然后在数据库中新建关系,把我们要建立关系的表都放到一起,根据主键和外键的关系,进行连接即可。通
31、过分析可以知道在这个系统中,我们共有9个实体,分别是:UserInfo ( user_id,user_pwduser,pepdom,user_mod,user_picture )TableInfo ( tablenum,persons,status,roomname )MenuInfo ( Menu_id,Menu_name,Menu_price,Menu_discount,Menu_style,Menu_sapor,Menu_description,Menu_material,Menu_picture )OrderItems (orderid,menu_id,customerid,table
32、num,roomname,orderdate,quantity,unitprice )OrderInfo (orderstyle,excutedate,shippeddate,shippdeaddress,is checked,roomname,tablenum )ClerkInfo ( clerkid,clerkname,sex,marry,dept,duty,salary,hiredate,tel,photopath,address )CustomerInfo (customerid,identy,consumesummary,consumercount,discountratio,log
33、indate )BookInfo ( orderid,orderstyle,orderdate,excutedte,relator,telephone,address,contents )BillInfo (billid,tablenum,roomname,sysdate,totalprice )同一张账单可同时对应多张饭桌,也可以同时有多道菜,则它们之间的关系就是一对多的关系。一个会员可以对应多张账单,所以它们之间的关系也是一对多的关系。而对于一个预定订单在同一时间只可对应一张账单;一个卖外订单在同一时间只可对应一张账单,则它们之间的关系是一对一的系。通过以上的分析,我们可以知道餐饮系统的关
34、系图如下所示:图2-2第三章餐饮系统中数据表格的实体完整性以前我们曾学过在定义关系模型时一定要指明属性的域,也就是我们常说的值域的取值范围。每当有新数据插入到数据库时或修改数据时,系统都要进行域约束检查,可见域约束是最基本的完整性约束。 而数据库的完整性就是指数据的正确性和相容性,它是指应防止数据库中存在不符合语义规定的数据,防止因错误信息的输入输出造成无效操作或产生错误信息。因此,为了维护数据库中数据与现实世界的一致性,对关系数据库的插入、删除和修改必须有一定的约束条件,这就是关系模型的三类完整性。 实体完整性(Entity Integrity)实体完整性就是指主码的值不能为空或者是部分为空
35、。也就是我们所说的关系中所有的主属性不能取空值。实体完整性规定表的每一行在表中是惟一的。实体表中定义的UNIQUE(惟一性约束)、PRIMARYKEY(主关键字约束)约束就是实体完整性的体现。如图:图3-1上面这个图是系统中外卖订单信息表“BookInfo”的参数设计,从图里面我们可以看出作为主键设置的OrderID是不允许为空的,而其它的非主码属性可以为空。这就是一个实体完整性的约束。这只是系统中的一个表,系统中其它表也和这个表一样,作为一个表的主键(主码)不能为空或者是部分为空。参照完整性(Referential Integrity)参照完整性定义了参照关系和被参照关系的外码与主码之间的参
36、照约束,即对参照关系的外码属性的约束,它规定了值域只能是空值或是相应被参照关系中主码属性的值。如:属性是关系的外码,它与关系的主码相对应,则对于每个元组在上的值必须为空值或者是等于中某个元组的主码值。例如:在我们所设计的餐饮系统中,预定订单信息表与饭桌信息表两个表的内容如下:图3-2其中饭桌信息表中的主键是tablenum(桌号),所以它的取值是不允许为空或者部分为空的。在预定订单信息表中的主键是orderID(订单号),其它的属性都是非主码属性。然而在这个表(预定订单信息表)中的tablenum(桌号)是该表的一个外部关系码,它的取值只可以是饭桌信息表中tablenum(饭桌号)属性的值或者
37、是为空。在这里tablenum(饭桌号)的取值只可以是到之间的任意整数或者是为空。也就是说预定订单信息表中某张订单的“tablenum”的取值,必须在参照的饭桌信息表中主码“tablenum”的值中能够找到,否则表示为预定订单信息表分配到一个不存在的饭桌号上进行用餐,这样显然是不符合语义的。用户自定义完整性(User-defined Integrity)用户自定义完整性是针对某一具体应用要求来定义的约束条件,它反映某一具体应用涉及的数据必须满足的定义要求。用户定义完整性通常是定义对关系中除主码与外码属性之外的其他属性取值的约束,即对其他属性的值域的约束。属性值根据实际需求,而所要具备一些约束条
38、件,如饭桌信息“TableInfo”关系中的使用人数不能为负数;某些数据的输入格式要有一些限制。通过上面的一些分析我们可以看出餐饮服务系统中的数据表是满足完整性约束的。l 注意:实体完整性和参照完整性是关系模型必须满足的完整性约束条件,被称作关系的两个变性。任何关系数据库系统都应该支持这两类完整性。在对关系数据库执行插入、删除和修改操作时,就要先检查完整性,规则如下:1) 当执行插入操作时,先检实体完整性规则,再检查参照完整性规则,最后检查用户自定义完整性规则。2) 当执行删除操作时,一般只检查参照完整性规则。3) 当执行更新操作时,可看成是先删除再插入的操作。因此,是上述两种情况的综合,故要
39、检查实体完整性规则、参照完整性规则和用户自定义完整性规则。第四章 餐饮系统中数据库的基本操作基本概念在建立了数据库关系图后,要进行的就是对数据库的一些基本语句的操作了。在以前学习了SQL之后,我们应该发现要学好SQL,就要掌握四条最基本的数据操作语句:Insert、Select、Update和Delete,这也就是我所要说的数据操纵语言(data manipulation language , DML)。而在本系统中我们也用到了这些基本的操作。下面我们就来介绍一下这4条基本的操作语句在餐饮服务系统中的一些运用。在对表进行插入、删除、选择、更新操作时,都必须建立一张表,有的需要修改表,有的还要删除表,那么我们就先学基本表的创建、修改和删除。l 创建基本表、create table 表名(列名数据类型列的完整性约束,列名数据类型列的完整性约束,表的完整性约束)其实还有一种更方便的方法就是通过使用SQL中的企业管理器来创建表。在创建新的数据表之前,我们先来建立一个数据库FoodServer,然后右键单击这个新建的数据库FoodServer,在展开的列表项中选择“新建”在展开的内容中再选择“表”即可创建一个表,然后就进入这个表的窗体,再进行参数的设计即可。
限制150内