收藏 分销(赏)

KTV管理系统专业资料.doc

上传人:快乐****生活 文档编号:3907738 上传时间:2024-07-23 格式:DOC 页数:38 大小:438.54KB
下载 相关 举报
KTV管理系统专业资料.doc_第1页
第1页 / 共38页
KTV管理系统专业资料.doc_第2页
第2页 / 共38页
KTV管理系统专业资料.doc_第3页
第3页 / 共38页
KTV管理系统专业资料.doc_第4页
第4页 / 共38页
KTV管理系统专业资料.doc_第5页
第5页 / 共38页
点击查看更多>>
资源描述

1、数据库技术课程设计课题 KTV管理系统 班级 08电子商务B 学号 姓名 张婷婷 2023年 7月 1日2023 年 7 月 8 日目录1需求分析:31.1现实需求分析31.2系统需求分析31.3数据库需求分析31.4 系统功能模块分析41.5据字典52数据库概念设计62.1局部概念模式设计62.2全局概念模式设计103.数据库逻辑设计113.1数据模型的映射113.2数据库结构优化和完整性设计123.3数据库的逻辑结构设计134数据库物理设计174.1:建库174.2建表184.3 将数据插入表中214.4建立视图234.5数据库索引的建立235.数据的实行与维护245.1查询245.2 触

2、发器255.3 存储过程281需求分析:1.1现实需求分析随着社会的发展和人民生活水平的提高,人们对精神文化生活的需求也在不断的增长。KTV的出现和发展满足了人们这种需求。各行业的发展和计算机系统的结合越来越紧密,很多歌厅借助现代高科技的所带来的优质的服务,大大提高服务的档次,提高了公司的管理水平,提高了竞争力达成管理的系统化,规范化。1.2系统需求分析KTV管理信息系统重要是完毕对歌厅的管理(涉及预定,开房,结账,维修,打扫)和各种相关信息的管理的录入和查询。用户登入系统,输入用户名和密码,系统从数据库的用户信息表进行核对,完全一致这进入系统。房间或会员信息的增长时,系统会把这些信息写入到数

3、据库中的房间和会员信息表中。若客人取消预定,则在预定单表中删除这些信息。当结账时,通过房间编号从房间消费表中读取消费信息。结账后,就把此行信息删除,写入到结账表中。假如是会员,消费的信息会写入到会员信息表中,消费的次数和消费的金额都将累加,假如消费金额达成一定的限度,这签单的金额度将发生变化。1.3数据库需求分析本系统是为一般歌厅设计的KTV管理系统,程序规定能录入一些基本的资料,需要对房间完毕对房间的预定,开房,结账等基本信息操作,并可以对这些信息进行记录,根据以上的需求,数据库的设计,必需满足一下几点:l 记录房间的基本信息:房间号,房间名称,房间类型,房间的价格,房间状态l 记录会员的基

4、本信息:会员编号,会员姓名,固定电话,手机,地址,签单的额度,消费次数,消费积分,备注。l 记录预订单信息:涉及预订单编号,客户名称,房间编号,房间类型,房间价格,客户地电话,人数,开房日期,开房时间,操作员,预付金额,会员编号,预定日期,备注。l 记录房间消费信息:开房单编号,房间编号,房间类型,房间价格,人数,客户名称,客户电话,开房时间,预付金额,付款方式,折扣,消费金额,开房日期,会员编号,备注l 记录账单信息:账单编号,房间编号,房间类型,房间价格,客户名称,开房时间,关房时间,预付金额,付款方式,折扣,消费金额,开房日期,会员的编号l 记录维修单信息:维修单编号,房间编号,维修因素

5、,维修结果l 记录维修单历史:维修单编号,房间编号,维修因素,维修结果l 记录用户信息,涉及用户ID,用户名,用户密码,用户权限代码,用户类型1.4 系统功能模块分析1根据以上的需求分析,KTV的功能模块如下: KTV管理系统基本信息基本业务查询记录系统设立退出系统房间信息会员信息预定开房结账维修打扫房间管理信息预订单开房单维修单账单查询房间查询状态类型会员查询用户设立密码设立用户查询图一系统功能模块图1 功能模块说明:l 基本信息模块:用于记录房间几会员的基本信息l 基本业务模块:重要解决房间的预定,开房,结账以及维修等项目。l 查询记录模块:重要用于对房间基本信息,会员基本信息的查询l 系

6、统设立模块:重要是 通用户设立,密码的设立,来加强对用户的管理,并且提高系统的安全性。l 退出系统1.5据字典数据字典重要是对数据结构(数据元素)、数据存储和数据解决进行更具体的相应。1 房间基本信息含义说明:KTV房间的基本信息(原始资料)组成:房间号,房间名称,房间类型,房间的价格,房间状态2 会员基本信息:含义说明:KTV的顾客可通过办理睬员卡成为KTV的会员,会员可以享受一些打折,积分换金钱优惠,会员基本信息表记录了所有会员的信息(是原始数据)。组成:会员编号,会员姓名,固定电话,手机,地址,签单的额度,消费次数,消费积分,备注3 房间消费信息:含义说明:记录当某个房间被预定或使用后发

7、生的所有消费(结账时需要用到这些数据)组成:订单编号,客户名称,房间编号,房间类型,房间价格,客户地电话,人数,开房日期,开房时间,操作员,预付金额,会员编号,预定日期,备注4 预定单信息含义说明:某些客户为了防止到期没房可以住,所以向KTV预定房间,预定需要交纳一定的定金,并且产生了预订单,依次作为预定的凭证,事后无论哪一方违约,可以此为证据。组成:账单编号,房间编号,房间类型,房间价格,客户名称,开房时间,关房时间,预付金额,付款方式,折扣,消费金额,开房日期,会员的编号5 账单信息:含义:用于记录消费时的账单的基本信息组成:编号,房间编号,房间类型,房间价格,人数,客户名称,客户电话,开

8、房时间,预付金额,付款方式,折扣,消费金额,开房日期,会员编号,备注6 维修单信息含义说明:随着时间的推移或者使用不妥,房间里的设备等会被损坏,因此要对这些房间进行维修,维修单记录了维修中的基本元素组成:维修单编号,房间编号,维修因素,维修结果7 维修历史含义:间不一定只修过一次,维修历史表将维修从时间的角度进行管理组成:维修单编号,房间编号,维修因素,维修结果8 用户信息含义:用于存储用户登录系统的基本信息组成:用户ID,用户名,用户密码,用户权限代码,用户类型2数据库概念设计21局部概念模式设计本系统的数据库所涉及到的实体有房间实体,会员实体,预单实体,开房单实体,账单实体,维修单实体,维

9、修单历史实体,用户实体,下面为各实体的E-R图1房间实体E-R图,属性涉及房间号,房间名称,房间类型,房间的价格,房间状态房间编号名称类型价格状态房间实体E-R图2.会员实体ER会员编号,会员姓名,固定电话,手机,地址,签单的额度,消费次数,消费积分,备注编号名称时间日期会员会员实体E_R图3.预订单实体E-R账单编号,房间编号,房间类型,房间价格,客户名称,开房时间,关房时间,预付金额,付款方式,折扣,消费金额,开房日期,会员的编号预订单实体编号名称日期会员编号预订单实体ER图4 开房实体E-R编号,房间编号,房间类型,房间价格,人数,客户名称,客户电话,开房时间,预付金额,付款方式,折扣,

10、消费金额,开房日期,会员编号,备注开房单实体编号开房时间客户名称会员编号开房实体E-R图5账单信息实体E-R图:编号,房间编号,房间类型,房间价格,人数,客户名称,客户电话,开房时间,预付金额,付款方式,折扣,消费金额,开房日期,会员编号,备注编号房间编号备注账单信息实体账单信息实体E-R图6 维修单信息维修单编号,房间编号,维修因素,维修结果维修单实体维修单编号房间编号维修缘由维修单实体E-R图7 维修历史E-R图维修单编号,房间编号,维修因素,维修结果维修单实体编号房间编号维修结果维修缘由维修单历史实体E-R图5 用户信息E-R图用户ID,用户名,用户密码,用户权限代码,用户类型用户实体编

11、号姓名密码权限类型用户实体E-R图2.2全局概念模式设计会员开房预定消费房间开房账单设立维修查看用户各实体之间关系E-R图在SQL数据中,各表的关系如下:3.数据库逻辑设计31数据模型的映射1.数据实体的映射:房间信息(房间号,房间名称,房间类型,房间的价格,房间状态)会员信息(会员编号,会员姓名,固定电话,手机,地址,签单的额度,消费次数,消费积分,备注)预订单信息(预订单编号,客户名称,房间编号,房间类型,房间价格,客户地电话,人数,开房日期,开房时间,操作员,预付金额,会员编号,预定日期,备注)房间消费信息(开房单编号,房间编号,房间类型,房间价格,人数,客户名称,客户电话,开房时间,预

12、付金额,付款方式,折扣,消费金额,开房日期,会员编号,备注)账单信息(账单编号,房间编号,房间类型,房间价格,客户名称,开房时间,关房时间,预付金额,付款方式,折扣,消费金额,开房日期,会员的编号)维修单信息(维修单编号,房间编号,维修因素)维修单历史(维修单编号,房间编号,维修因素,维修结果)用户登录信息(用户ID,用户名,用户密码,用户权限代码,用户类型)3.2数据库结构优化和完整性设计1建立表之间的联系,如图 2建立存储过程ExistByID,查看某个表中是否存在某个整形字段等于某个值的记录use KTVDBGO/*查看某个数据表中,是否存在某个字段等于某个值的记录*/create Pr

13、oc dbo.ExistByID(strTableName varchar(225),strFiledName varchar(225),intFieldValue int,bitResult bit Output)asset Nocount ondeclare strSQL varchar(3000)declare nCount int/*构建存储符号条件的记录数的临时表 */if Object_ID(DBO.#tmpTable) is nullcreate table #tmpTable(tepField int )else truncate table #tmpTable/*在数据库表中

14、检索符合条件的记录数,并且存储在临时表中*/select strSQL=select count(+strFiledName+) from +strTableName+e+strFiledName+=+convert(varchar(50),intFieldValue)select strSQL=insert #tmpTable +strSQLexec(strSQL)/*在临时表中返回存储记录数*/select top 1 nCount =tmpField from #tmpTable order by tmpField drop table #tmpTableif nCount0select

15、 bitResult =1elseselect bitResult =0go3.3数据库的逻辑结构设计1数据库中的八个表的逻辑结构图,为表41 用户登入信息表 UseInfo字段名字段说明数据类型字段长度必填字段主键UserID 用户IDchar2是是Username用户姓名varchar8否否UserPwd用户密码varchar10是否UserType用户权限代码int4否否Remake用户类型varchar8否否 表4-2 房间信息表 RoomInfo字段名字段说明数据类型字段长度必填字段主键RoomID房间编号char2是是RoomName房间名称varchar20否否RoomTypeN

16、ame房间类型varchar10否否RoomPrice价格float8是否RoomState房间状态char6否否表4-3会员信息表MemberInfo字段名字段说明数据类型字段长度必填字段主键MemberID会员编号char3是是MemberName会员姓名varchar8否否Tel1固定电话varchar20否否Tel2手机varchar20否否Address地址varchar30否否SignCheck签单额度int4是否ConsumedTime消费次数int4是否ConsumedIntegral消费积分float8是否Remake备注varchar50否否表4-4 预订单信息表Desti

17、neInfo字段名字段说明数据类型字段长度必填字段主键DestineID预订单编号char4是是ClientName客户名称varchar10否否RoomID房间编号char2是否RoomType房间类型varchar8否否RoomPrice房间价格float8否否ClientTel客户电话varchar20否否ClientCount人数int4否否OpenRoomDate开房日期datetime8是否OpenRoomTime开房时间datetime8是否Waitor操作员varchar10否否Prepry预付金额float8否否Remake备注varchar50否否DestineDate预订

18、日期datetime8是否MemberID会员编号char3否否表4-5 房间消费信息表 RoomConsumed字段名字段说明数据类型字段长度必填字段主键RoomConsumed开房编号char4是是RoomID房间编号char10是否RoomType房间类型varchar2否否RoomPrice房间价格float8否否ClientCount人数int8否否ClientName客人姓名varchar20否否OpenTime开房时间datetime4是否ClientTel客户电话varchar8否否Prepay预付定金float8否否Agio折扣int10否否PayMode付款方式varcha

19、r8否否OpenDate开房日期datetime8是否Remake备注datetime50是否MemberID会员编号varchar3否否表4-6结账单信息表 CheckInfo字段名字段说明数据类型字段长度必填字段主键CheckID结账单编号char4是是RoomID房间编号char2是否RoomType房间类型varchar10否否RoomPrice房间价格float8否否ClientName客人姓名varchar10否否Agio折扣int4否否OpenRoomTime开房时间datetime8是否EndTime结账时间datetime8是否Prepay预付定金float8否否PayMod

20、e付款方式varchar10否否RoomMoney消费金额float8是否OpenDate开房日期datetime8是否MemberID会员编号varchar3否否表4-7维修单信息表 RepairInfo字段名字段说明数据类型字段长度必填字段主键RepairID维修编号char3是是RoomID房间编号char2是否Remakr维修缘由varchar50否否表4- 8 维修单历史表 RepairHistory字段名字段说明数据类型字段长度必填字段主键RepairHisID维修编号char3是是RoomID房间编号char2是否Remakr维修缘由varchar50否否RemakrAfter维

21、修结果varchar50否否 4数据库物理设计物理设计的目的不仅要保证存储数据的适当结构,并且要以适当的方式对性能提供保证。数据库物理设计重要涉及以下两方面的工作:l 数据库的数据文献的分布结构。l 拟定索引的结果。4.1:建库IF exists(select * from sysdatabases where name =KTVDB)drop database KTVDBcreate database KTVDBon(name=KTVDB_dat,filename =D:KTVDBKTVDB.MDF,SIZE=5MB,maxsize=20MB,filegrowth =2MB)LOG ON(n

22、ame =KTVDB_log,filename =D:KTVDBKTVDB.ldf,size=2MB,filegrowth=15%)42建表1 用户登录use KTVDBGOcreate table UseInfo(UserID char(2) primary key not null,Usename varchar(10),UsePwd varchar(10) not null,UseType int,Remake varchar(10)2房间信息create table RoomInfo(RoomID char(2) primary key not null,Roomname varcha

23、r(20),RoomTypeName varchar(10),RoomPrice Float not null,RoomState char(6)3会员信息create table MemberInfo(MemberID char(3) primary key not null,MemberName varchar(8),Tel1 varchar(20),Tel2 varchar(20),Address varchar(30),SignCheck int not null,ConsumedTime int not null,ConsumeIntegral float not null,Rema

24、ke varchar(50)4预订单信息create table DestineInfo(DestineID char(4) primary key not null,ClientName varchar(10),RoomID char(2) not null,RoomType varchar(8),RoomPrice Float,ClientTel varchar(20),ClientCount int,OpenRoomDate datetime not null,OpenRoomTime datetime not null,Waitor varchar(10),Prepay float,R

25、emake varchar(50),DestineDate datetime,MemberID char(3)5房间消费信息create table RoomConsumed(RoomConsumedID char(4) primary key not null,RoomID char(2) not null,RoomType varchar(10),RoomPrice Float ,ClientCount int,ClientName varchar(8),OpenTime datetime not null,ClientTel varchar(20),Prepay float,Agio i

26、nt,PayMode Varchar(8),OpenDate datetime not null,Remake varchar(50),MemberID char(3)6账单信息create table CheckInfo(CheckID char(10)primary key not null,RoomID char(2) not null,RoomType varchar(10),RoomPrice Float ,ClientName varchar(10),Agio int,OpenRoomTime datetime not null,EndTime datetime not null,

27、Prepay float,PayMode Varchar(8),RoomMoney float not null,OpenDate datetime not null,MemberID char(3)7维修单信息create table RepairInfo(RepairID char(3)primary key not null,RoomID char(2) not null,Remake varchar(50)8维修单历史create table RepairHistory(RepairHisID char(3)primary key not null,RoomID char(2) not

28、 null,Remake varchar(50),RemakeAfter varchar(50)4.3 将数据插入表中图4-1 UserInfo 图4-2 RoomInfo 图4-3 MemberInfo图4-4 DestineID 图4-5RoomConsumed图4-6 CheckInfo图4-7RepairInfo图4-8RepairHistory4.4建立视图发明视图的好处是,可以在别的视图或者用户自定义函数中,按照各种不同条件过滤该视图的检索数据而不要各自内在构造复杂的检索条件并在相应的表中检索数据。为用户登录表创建视图4.5数据库索引的建立索引可加快查询的,还可以对数据进行唯一的标

29、记现在为个张表的主键建立索引为UseID ,RoomID,MemberID,DestineID, RoomConsumedID CheckID RepairID RepairHisID 创建索引use KTVDBGOcreate index index_UserID on UseInfo(UserID )create index index_RoomID on RoomInfo(RoomID )create index index_MemberID on MemberInfo (MemberID )create index index_DestineID on DestineInfo (Des

30、tineID )create index index_RoomConsumedID on RoomConsumed(RoomConsumedID )create index index_CheckID on CheckInfo(CheckID )create index index_RepairID on RepairInfo(RepairID )create index index_RepairHisID on RepairHistory(RepairHisID )5.数据的实行与维护5.1查询1)嵌套查询查询房间信息表中,房间状态为空并且不在维修单信息表中的房间的所有信息,同时显示“这些房

31、间可以正常营业”use KTVDBGOif exists(select * from RoomInfowhere RoomID not in (select RoomID from RepairInfo ) and RoomState=空)beginprint 这些房间可以正常营业end2)变量查询查找积分比小文多的会员的所有信息此代码中用到变量,变量有很大的灵活性,可以通过直接改变赋值来进行各种不同的查询52 触发器1)结账的时间一般有结账时系统直接给出,不能修改。假如修改了,则会给出警告,并且修改失败。use KTVDBGOcreate trigger 结账时间修改on CheckInfo

32、for updateasif update(EndTime)beginprint结账失败!raiserror(安全警告:结账日期不能修改,结账时由系统直接给出,16,1)rollback transactionendgo现在修改EndTime中的数据,系统将给出如下警告2)创建一个触发器,查询会员信息,假如消费积分超过10000分,则签单额度可以增长2023元。use KTVDBGOcreate trigger 签单额度增长on MemberInfofor updateas if exists (select * from MemberInfo where ConsumeIntegral100

33、00)beginupdate MemberInfo set SignCheck=SignCheck+2023end例如会员小超,本来的签单额度为修改后的签单额度为:3)更新住房信息时,同时也会更新会员表的金额和消费的次数create trigger RoomConsumed_inserton dbo.RoomConsumedfor insertasupdate Mset M.ConsumedTime=(M.ConsumedTime+1),M.SignCheck=(M.SignCheck+RC.RoomPrice )from MemberInfo as M inner join RoomCons

34、umed as RCON M.MemberID=RC.MemberID向表中插入数据对比修改前后的MemberInfo修改前的表修改后的表4)假如某个房间有人住,则房间的状态为使用中use KTVDBGO/*假如某个房间有人住时,则房间状态为使用中,假如无人住,则为空房*/create trigger RoomState_update1on dbo.RoomConsumedfor updateasif exists(select ClientName from RoomConsumed)begin update RoomInfoset RoomState=使用中from RoomInfo wh

35、ere RoomID in (select RoomID from RoomConsumed )end向RoomConsumed 表中插入信息再查看RoomID表修改前修改后5.3 存储过程1)验证用户名和密码,并输出验证结果,用户编号,真实姓名,用户类型use KTVDBGO/*验证用户名和密码,并输出验证结果,用户编号,真实姓名,用户类型*/create proc dbo.IsValidUser(Usename varchar(10),UsePwd varchar(10) ,UserID int output, UseType bit output,/*输出值(VB组建自定义的枚举数),为

36、合法用户,为用户名错,为密码错*/ReturnValue int output)as declare RightPwd varchar(10)select top 1 RightPwd =UsePwd,UserID=UserID,UseType =UseType from UseInfo where Usename=Usename order by Usename/*用户名不存在*/if RightPwd is nullbegin set ReturnValue=2returnend/*用户名不在,则比较密码*/if RightPwd UsePwdbeginset ReturnValue=3r

37、eturn end2)建立存储过程计算结账时的金额use KTVDBGOcreate ProCedure up_checkcOpenTime datetime,cCloseTime datetime,cRoomID CHAR(4),cPrice float,cAgio int,cPrepay int,Money float outputasselect cPrice =RoomPrice from RoomInfo where RoomID=cRoomIDselect cOpenTime =OpenTime from RoomConsumed where RoomID=cRoomIDselec

38、t cPrepay= Prepay from RoomConsumed where RoomID=cRoomIDselect cCloseTime =Getdate()select Money=(datediff(mi,cOpenTime,cCloseTime)*cPrice/60.0*cAgio/100.0-cPrepay3)积分超过一万分的为“钻石级会员”,建立一个存储过程,找出这些会员,并输出这些会员的信息。并且将remark中的值改为“钻石级会员”create proc 钻石会员cit float=10000,citsum int outputasprint -print本KTV的钻石

39、级会员为select * from MemberInfowhere ConsumeIntegralcitselect citsum=count(MemberID)from MemberInfowhere ConsumeIntegralcitupdate MemberInfoset Remake=钻石级会员where ConsumeIntegralcitdeclare citsum intexec 钻石会员1000,citsum outputselect citsumupdate MemberInfoset Remake=钻石级会员where ConsumeIntegral100004)建立带游

40、标的存储过程,将维修单信息表中的备注添加到维修单历史表中的“备注”字段create proc 维修历史单添加asdeclare RoomID char(2),Remark varchar(50)declare cursor_添加cursorforselect RoomID,Remake from RepairHistorywhere Remake is null and RoomID is not null open cursor_添加fetch next from cursor_添加into RoomID,Remarkwhile fetch_status=0beginselect Remark=Remake from RepairInfo where RoomID=RoomID update RepairHistory set Remake=Remark where RoomID=RoomID if exists(select RoomID,Remake from RepairHistorywhere Remake is null and RoomID is not null )continueelsebreakendexec 维修历史单添加select * from RepairHistory 修改前后比较

展开阅读全文
相似文档                                   自信AI助手自信AI助手
猜你喜欢                                   自信AI导航自信AI导航
搜索标签

当前位置:首页 > 包罗万象 > 大杂烩

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2024 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服