1、数据库技术课程设计课题 KTV管理系统 班级 08电子商务B 学号 012119 姓名 张婷婷 7月 1日 年 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 触发器255.3
2、 存储过程281需求分析:1.1现实需求分析随着社会发展和人民生活水平提高,人们对精神文化生活需求也在不断增长。KTV浮现和发展满足了人们这种需求。各行业发展和计算机系统结合越来越紧密,诸多歌厅借助当代高科技所带来优质服务,大大提高服务档次,提高了公司管理水平,提高了竞争力达到管理系统化,规范化。1.2系统需求分析KTV管理信息系统重要是完毕对歌厅管理(涉及预定,开房,结账,维修,打扫)和各种有关信息管理录入和查询。顾客登入系统,输入顾客名和密码,系统从数据库顾客信息表进行核对,完全一致这进入系统。房间或会员信息增长时,系统会把这些信息写入到数据库中房间和会员信息表中。若客人取消预定,则在预定
3、单表中删除这些信息。当结账时,通过房间编号从房间消费表中读取消费信息。结账后,就把此行信息删除,写入到结账表中。如果是会员,消费信息会写入到会员信息表中,消费次数和消费金额都将累加,如果消费金额达到一定限度,这签单金额度将发生变化。1.3数据库需求分析本系统是为普通歌厅设计KTV管理系统,程序规定能录入某些基本资料,需要对房间完毕对房间预定,开房,结账等基本信息操作,并可以对这些信息进行记录,依照以上需求,数据库设计,必须满足一下几点:l 记录房间基本信息:房间号,房间名称,房间类型,房间价格,房间状态l 记录会员基本信息:会员编号,会员姓名,固定电话,手机,地址,签单额度,消费次数,消费积分
4、,备注。l 记录预订单信息:涉及预订单编号,客户名称,房间编号,房间类型,房间价格,客户地电话,人数,开房日期,开房时间,操作员,预付金额,会员编号,预定日期,备注。l 记录房间消费信息:开房单编号,房间编号,房间类型,房间价格,人数,客户名称,客户电话,开房时间,预付金额,付款方式,折扣,消费金额,开房日期,会员编号,备注l 记录账单信息:账单编号,房间编号,房间类型,房间价格,客户名称,开房时间,关房时间,预付金额,付款方式,折扣,消费金额,开房日期,会员编号l 记录维修单信息:维修单编号,房间编号,维修因素,维修成果l 记录维修单历史:维修单编号,房间编号,维修因素,维修成果l 记录顾客
5、信息,涉及顾客ID,顾客名,顾客密码,顾客权限代码,顾客类型1.4 系统功能模块分析1依照以上需求分析,KTV功能模块如下: KTV管理系统基本信息基本业务查询记录系统设立退出系统房间信息会员信息预定开房结账维修打扫房间管理信息预订单开房单维修单账单查询房间查询状态类型会员查询顾客设立密码设立顾客查询图一系统功能模块图1 功能模块阐明:l 基本信息模块:用于记录房间几会员基本信息l 基本业务模块:重要解决房间预定,开房,结账以及维修等项目。l 查询记录模块:重要用于对房间基本信息,会员基本信息查询l 系统设立模块:重要是 通顾客设立,密码设立,来加强对顾客管理,并且提高系统安全性。l 退出系统
6、1.5据字典数据字典重要是对数据构造(数据元素)、数据存储和数据解决进行更详细相应。1 房间基本信息含义阐明:KTV房间基本信息(原始资料)构成:房间号,房间名称,房间类型,房间价格,房间状态2 会员基本信息:含义阐明:KTV顾客可通过办理睬员卡成为KTV会员,会员可以享有某些打折,积分换金钱优惠,会员基本信息表记录了所有会员信息(是原始数据)。构成:会员编号,会员姓名,固定电话,手机,地址,签单额度,消费次数,消费积分,备注3 房间消费信息:含义阐明:记录当某个房间被预定或使用后发生所有消费(结账时需要用到这些数据)构成:订单编号,客户名称,房间编号,房间类型,房间价格,客户地电话,人数,开
7、房日期,开房时间,操作员,预付金额,会员编号,预定日期,备注4 预定单信息含义阐明:某些客户为了防止到期没房可以住,因此向KTV预定房间,预定需要交纳一定定金,并且产生了预订单,依次作为预定凭证,事后无论哪一方违约,可以此为证据。构成:账单编号,房间编号,房间类型,房间价格,客户名称,开房时间,关房时间,预付金额,付款方式,折扣,消费金额,开房日期,会员编号5 账单信息:含义:用于记录消费时账单基本信息构成:编号,房间编号,房间类型,房间价格,人数,客户名称,客户电话,开房时间,预付金额,付款方式,折扣,消费金额,开房日期,会员编号,备注6 维修单信息含义阐明:随着时间推移或者使用不当,房间里
8、设备等会被损坏,因而要对这些房间进行维修,维修单记录了维修中基本元素构成:维修单编号,房间编号,维修因素,维修成果7 维修历史含义:间不一定只修过一次,维修历史表将维修从时间角度进行管理构成:维修单编号,房间编号,维修因素,维修成果8 顾客信息含义:用于存储顾客登录系统基本信息构成:顾客ID,顾客名,顾客密码,顾客权限代码,顾客类型2数据库概念设计21局部概念模式设计本系统数据库所涉及到实体有房间实体,会员实体,预单实体,开房单实体,账单实体,维修单实体,维修单历史实体,顾客实体,下面为各实体E-R图1房间实体E-R图,属性涉及房间号,房间名称,房间类型,房间价格,房间状态房间编号名称类型价格
9、状态房间实体E-R图2.会员实体ER会员编号,会员姓名,固定电话,手机,地址,签单额度,消费次数,消费积分,备注编号名称时间日期会员会员实体E_R图3.预订单实体E-R账单编号,房间编号,房间类型,房间价格,客户名称,开房时间,关房时间,预付金额,付款方式,折扣,消费金额,开房日期,会员编号预订单实体编号名称日期会员编号预订单实体ER图4 开房实体E-R编号,房间编号,房间类型,房间价格,人数,客户名称,客户电话,开房时间,预付金额,付款方式,折扣,消费金额,开房日期,会员编号,备注开房单实体编号开房时间客户名称会员编号开房实体E-R图5账单信息实体E-R图:编号,房间编号,房间类型,房间价格
10、,人数,客户名称,客户电话,开房时间,预付金额,付款方式,折扣,消费金额,开房日期,会员编号,备注编号房间编号备注账单信息实体账单信息实体E-R图6 维修单信息维修单编号,房间编号,维修因素,维修成果维修单实体维修单编号房间编号维修缘由维修单实体E-R图7 维修历史E-R图维修单编号,房间编号,维修因素,维修成果维修单实体编号房间编号维修成果维修缘由维修单历史实体E-R图5 顾客信息E-R图顾客ID,顾客名,顾客密码,顾客权限代码,顾客类型顾客实体编号姓名密码权限类型顾客实体E-R图2.2全局概念模式设计会员开房预定消费房间开房账单设立维修查看顾客各实体之间关系E-R图在SQL数据中,各表关系
11、如下:3.数据库逻辑设计31数据模型映射1.数据实体映射:房间信息(房间号,房间名称,房间类型,房间价格,房间状态)会员信息(会员编号,会员姓名,固定电话,手机,地址,签单额度,消费次数,消费积分,备注)预订单信息(预订单编号,客户名称,房间编号,房间类型,房间价格,客户地电话,人数,开房日期,开房时间,操作员,预付金额,会员编号,预定日期,备注)房间消费信息(开房单编号,房间编号,房间类型,房间价格,人数,客户名称,客户电话,开房时间,预付金额,付款方式,折扣,消费金额,开房日期,会员编号,备注)账单信息(账单编号,房间编号,房间类型,房间价格,客户名称,开房时间,关房时间,预付金额,付款方
12、式,折扣,消费金额,开房日期,会员编号)维修单信息(维修单编号,房间编号,维修因素)维修单历史(维修单编号,房间编号,维修因素,维修成果)顾客登录信息(顾客ID,顾客名,顾客密码,顾客权限代码,顾客类型)3.2数据库构造优化和完整性设计1建立表之间联系,如图 2建立存储过程ExistByID,查看某个表中与否存在某个整形字段等于某个值记录use KTVDBGO/*查看某个数据表中,与否存在某个字段等于某个值记录*/create Proc dbo.ExistByID(strTableName varchar(225),strFiledName varchar(225),intFieldValue
13、 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/*在数据库表中检索符合条件记录数,并且存储在暂时表中*/select strSQL=select count(+strFiledName+) from +strTableName+e
14、+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 bitResult =1elseselect bitResult =0go3.3数据库逻辑构造设计1数据库中八个表逻辑构造图,为表41 顾客登入信息表 UseInfo字
15、段名字段阐明数据类型字段长度必填字段主键UserID 顾客IDchar2是是Username顾客姓名varchar8否否UserPwd顾客密码varchar10是否UserType顾客权限代码int4否否Remake顾客类型varchar8否否 表4-2 房间信息表 RoomInfo字段名字段阐明数据类型字段长度必填字段主键RoomID房间编号char2是是RoomName房间名称varchar20否否RoomTypeName房间类型varchar10否否RoomPrice价格float8是否RoomState房间状态char6否否表4-3会员信息表MemberInfo字段名字段阐明数据类型字
16、段长度必填字段主键MemberID会员编号char3是是MemberName会员姓名varchar8否否Tel1固定电话varchar20否否Tel2手机varchar20否否Address地址varchar30否否SignCheck签单额度int4是否ConsumedTime消费次数int4是否ConsumedIntegral消费积分float8是否Remake备注varchar50否否表4-4 预订单信息表DestineInfo字段名字段阐明数据类型字段长度必填字段主键DestineID预订单编号char4是是ClientName客户名称varchar10否否RoomID房间编号char2
17、是否RoomType房间类型varchar8否否RoomPrice房间价格float8否否ClientTel客户电话varchar20否否ClientCount人数int4否否OpenRoomDate开房日期datetime8是否OpenRoomTime开房时间datetime8是否Waitor操作员varchar10否否Prepry预付金额float8否否Remake备注varchar50否否DestineDate预订日期datetime8是否MemberID会员编号char3否否表4-5 房间消费信息表 RoomConsumed字段名字段阐明数据类型字段长度必填字段主键RoomConsum
18、ed开房编号char4是是RoomID房间编号char10是否RoomType房间类型varchar2否否RoomPrice房间价格float8否否ClientCount人数int8否否ClientName客人姓名varchar20否否OpenTime开房时间datetime4是否ClientTel客户电话varchar8否否Prepay预付定金float8否否Agio折扣int10否否PayMode付款方式varchar8否否OpenDate开房日期datetime8是否Remake备注datetime50是否MemberID会员编号varchar3否否表4-6结账单信息表 CheckInf
19、o字段名字段阐明数据类型字段长度必填字段主键CheckID结账单编号char4是是RoomID房间编号char2是否RoomType房间类型varchar10否否RoomPrice房间价格float8否否ClientName客人姓名varchar10否否Agio折扣int4否否OpenRoomTime开房时间datetime8是否EndTime结账时间datetime8是否Prepay预付定金float8否否PayMode付款方式varchar10否否RoomMoney消费金额float8是否OpenDate开房日期datetime8是否MemberID会员编号varchar3否否表4-7维修
20、单信息表 RepairInfo字段名字段阐明数据类型字段长度必填字段主键RepairID维修编号char3是是RoomID房间编号char2是否Remakr维修缘由varchar50否否表4- 8 维修单历史表 RepairHistory字段名字段阐明数据类型字段长度必填字段主键RepairHisID维修编号char3是是RoomID房间编号char2是否Remakr维修缘由varchar50否否RemakrAfter维修成果varchar50否否 4数据库物理设计物理设计目不但要保证存储数据恰当构造,并且要以恰当方式对性能提供保证。数据库物理设计重要涉及如下两方面工作:l 数据库数据文献分布
21、构造。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(name =KTVDB_log,filename =D:KTVDBKTVDB.ldf,size=2MB,filegrowth=15%)42建表1 顾客登录use KTVDBGOcreate ta
22、ble 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 varchar(20),RoomTypeName varchar(10),RoomPrice Float not null,RoomState char(6)3会员信息create table Membe
23、rInfo(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,Remake varchar(50)4预订单信息create table DestineInfo(DestineID char(4) primary key not null,ClientName v
24、archar(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,Remake varchar(50),DestineDate datetime,MemberID char(3)5房间消费信息create table RoomConsumed(RoomCons
25、umedID 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 int,PayMode Varchar(8),OpenDate datetime not null,Remake varchar(50),MemberID char(3)6账单信息create
26、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,Prepay float,PayMode Varchar(8),RoomMoney float not null,OpenDate datetime not null,MemberID cha
27、r(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 null,Remake varchar(50),RemakeAfter varchar(50)4.3 将数据插入表中图4-1 UserInfo 图4-2 RoomInfo 图4-3 Memb
28、erInfo图4-4 DestineID 图4-5RoomConsumed图4-6 CheckInfo图4-7RepairInfo图4-8RepairHistory4.4建立视图创造视图好处是,可以在别视图或者顾客自定义函数中,按照各种不同条件过滤该视图检索数据而不要各自内在构造复杂检索条件并在相应表中检索数据。为顾客登录表创立视图4.5数据库索引建立索引可加快查询,还可以对数据进行唯一标记当前为个张表主键建立索引为UseID ,RoomID,MemberID,DestineID,RoomConsumedID CheckID RepairID RepairHisID 创立索引use KTVDB
29、GOcreate 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 (DestineID )create index index_RoomConsumedID on RoomConsumed(RoomConsumedID )create index index_CheckID on Ch
30、eckInfo(CheckID )create index index_RepairID on RepairInfo(RepairID )create index index_RepairHisID on RepairHistory(RepairHisID )5.数据实行与维护5.1查询1)嵌套查询查询房间信息表中,房间状态为空并且不在维修单信息表中房间所有信息,同步显示“这些房间可以正常营业”use KTVDBGOif exists(select * from RoomInfowhere RoomID not in (select RoomID from RepairInfo ) and R
31、oomState=空)beginprint 这些房间可以正常营业end2)变量查询查找积分比小文多会员所有信息此代码中用到变量,变量有很大灵活性,可以通过直接变化赋值来进行各种不同查询52 触发器1)结账时间普通有结账时系统直接给出,不能修改。如果修改了,则会给出警告,并且修改失败。use KTVDBGOcreate trigger 结账时间修改on CheckInfofor updateasif update(EndTime)beginprint结账失败!raiserror(安全警告:结账日期不能修改,结账时由系统直接给出,16,1)rollback transactionendgo当前修改
32、EndTime中数据,系统将给出如下警告2)创立一种触发器,查询会员信息,如果消费积分超过10000分,则签单额度可以增长元。use KTVDBGOcreate trigger 签单额度增长on MemberInfofor updateas if exists (select * from MemberInfo where ConsumeIntegral10000)beginupdate MemberInfo set SignCheck=SignCheck+end例如会员小超,本来签单额度为修改后签单额度为:3)更新住房信息时,同步也会更新会员表金额和消费次数create trigger Ro
33、omConsumed_inserton dbo.RoomConsumedfor insertasupdate Mset M.ConsumedTime=(M.ConsumedTime+1),M.SignCheck=(M.SignCheck+RC.RoomPrice )from MemberInfo as M inner join RoomConsumed as RCON M.MemberID=RC.MemberID向表中插入数据对比修改先后MemberInfo修改前表修改后表4)如果某个房间有人住,则房间状态为使用中use KTVDBGO/*如果某个房间有人住时,则房间状态为使用中,如果无人住,
34、则为空房*/create trigger RoomState_update1on dbo.RoomConsumedfor updateasif exists(select ClientName from RoomConsumed)begin update RoomInfoset RoomState=使用中from RoomInfo where RoomID in (select RoomID from RoomConsumed )end向RoomConsumed 表中插入信息再查看RoomID表修改前修改后5.3 存储过程1)验证顾客名和密码,并输出验证成果,顾客编号,真实姓名,顾客类型use
35、 KTVDBGO/*验证顾客名和密码,并输出验证成果,顾客编号,真实姓名,顾客类型*/create proc dbo.IsValidUser(Usename varchar(10),UsePwd varchar(10) ,UserID int output,UseType bit output,/*输出值(VB组建自定义枚举数),为合法顾客,为顾客名错,为密码错*/ReturnValue int output)as declare RightPwd varchar(10)select top 1 RightPwd =UsePwd,UserID=UserID,UseType =UseType f
36、rom UseInfo where Usename=Usename order by Usename/*顾客名不存在*/if RightPwd is nullbegin set ReturnValue=2returnend/*顾客名不在,则比较密码*/if RightPwd UsePwdbeginset ReturnValue=3return end2)建立存储过程计算结账时金额use KTVDBGOcreate ProCedure up_checkcOpenTime datetime,cCloseTime datetime,cRoomID CHAR(4),cPrice float,cAgio
37、 int,cPrepay int,Money float outputasselect cPrice =RoomPrice from RoomInfo where RoomID=cRoomIDselect cOpenTime =OpenTime from RoomConsumed where RoomID=cRoomIDselect cPrepay= Prepay from RoomConsumed where RoomID=cRoomIDselect cCloseTime =Getdate()select Money=(datediff(mi,cOpenTime,cCloseTime)*cP
38、rice/60.0*cAgio/100.0-cPrepay3)积分超过一万分为“钻石级会员”,建立一种存储过程,找出这些会员,并输出这些会员信息。并且将remark中值改为“钻石级会员”create proc 钻石会员cit float=10000,citsum int outputasprint -print本KTV钻石级会员为select * from MemberInfowhere ConsumeIntegralcitselect citsum=count(MemberID)from MemberInfowhere ConsumeIntegralcitupdate MemberInfos
39、et Remake=钻石级会员where ConsumeIntegralcitdeclare citsum intexec 钻石会员1000,citsum outputselect citsumupdate MemberInfoset Remake=钻石级会员where ConsumeIntegral100004)建立带游标存储过程,将维修单信息表中备注添加到维修单历史表中“备注”字段create proc 维修历史单添加asdeclare RoomID char(2),Remark varchar(50)declare cursor_添加cursorforselect RoomID,Rema
40、ke 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 修改先后比较