数据库课程设计报告-宾馆信息管理系统
数据库课程设计__宾馆客房信息管理系统

一、設計內容與設計要求1.設計內容:資料庫系統原理的課程設計要求學生綜合利用本課程的有關知識,在教師的指導下,利用特定的資料庫設計環境,針對具體的問題,完成從系統的需求分析、資料庫的概念設計、資料庫的邏輯設計,到資料庫實現等設計過程,最終實現一個較為完整的反映應用需求的資料庫系統。
因此,在設計中,要求學生應該全面考慮各個設計環節以及它們之間的相互聯繫。
下麵是各個設計階段的具體內容。
⒈系統需求分析需求分析是資料庫系統設計的一個重要的環節。
本階段應該對整個應用情況作全面的、詳細的調查,確定特定資料庫應用環境下的設計目標,收集該應用環境下針對系統設計所需要的基礎數據以及對這些數據的具體存儲要求,從而確定用戶的需求。
用戶對數據庫的需求包括:⑴處理需求。
即用戶要完成什麼處理功能等。
學生在設計中應根據具體的課題要求確定系統應該實現的功能,一些基本的功能通常是必須具備的,如用戶的管理與維護,基本數據的維護,靈活的資訊查詢等。
⑵資訊需求。
即在資料庫中需要存儲哪些數據。
學生應該根據具體的課題,認真分析有關的要求,確定本設計的資訊需求。
⑶安全性和完整性功能。
實踐中這是一個需要與用戶不斷交流才能逐步確定的需求。
本課程設計要求學生在自己的設計中能反映出基本的安全性和完整性功能。
本階段的設計結果(即系統需求分析)應該在課程設計報告中進行詳細描述,畫出系統的數據流圖,寫出較為詳細的數據字典,作為本課程設計的驗收依據之一。
⒉資料庫的概念設計資料庫的概念設計是在需求分析的基礎上,利用與用戶雙方都能理解的形式,設計出資料庫的概念模型。
本課程設計要求學生採用E-R方法進行資料庫的概念設計。
本設計階段可分為:● 數據抽象。
即根據需求分析的結果,抽取出與本課程設計相關的特性。
設計局部概念模式。
運用E-R方法,設計出系統的各個局部ER模型。
● 設計全局概念模式。
通過對局部E-R模型的操作,解決各個E-R模型關於對象定義不一致問題,以及對各個E-R模型進行合併優化等,最終形成資料庫的全局概念模式。
宾馆管理系统数据库应用课程设计报告

西南科技大学数据库应用课程设计报告宾馆管理系统数据库设计学生姓名:学号:班级:指导老师:学院:提交日期:2016 年6月8日数据库应用课程设计评阅目录前言 (4)1.需求分析 (4)1.1系统功能背景资料 (4)1.2系统功能 (4)2.概要结构设计 (5)3.逻辑结构设计 (7)3.1关系模式设计 (7)3.2 关系模式的分析优化 (8)4.数据库物理设计 (10)5.数据库实施 (12)5.1.1各数据表说明 (12)5.1.2数据库创建 (12)5.2数据库操作 (12)6.部分系统功能实现 (16)7.总结 (18)前言在计算机技术发达的今天,各行各业都能利用计算机、网络来优化自己的业务,使业务简洁化、有序化。
宾馆管理系统能为宾馆提供如下功能:通过房间号查询该房间的等级/价位与入住信息;通过订单号查询单次入住信息及消费情况;通过身份证号查询该客户等级,入住记录;通过日期查询宾馆当月资产变化记录。
1. 需求分析设计本系统模拟宾馆内的工作人员及房间资金等管理内容,包括房间管理、客人入住、店内消费管理、结算管理、实现分类查询、输出相应的数据报表。
系统需要管理的情况如下:房间管理、客人入住、店内消费管理、结算管理、实现分类查询、输出相应的数据报表。
宾馆管理系统能为宾馆提供如下功能:通过房间号查询该房间的等级/价位与入住信息;通过订单号查询单次入住信息及消费情况;通过身份证号查询该客户等级,入住记录;通过日期查询宾馆当月资产变化记录。
1.1系统功能背景资料客户在邮局订购报纸的管理内容包括:1).宾馆有一名总经理、多名会计和多名前台。
总经理负责宾馆的日常运营,会计负责对宾馆收入支出的统计管理,前台数据包括职工号等。
职工号在宾馆内唯一。
2).宾馆有各种标准的房间。
房间数据包括房间号、房间级别、房间价位以及房间的状态(是否已经有客人)。
房间号唯一表示一个房间,房间级别决定房间价位,房间有多种级别分别表示:单人间、标准间、豪华间、商务间、行政间。
数据库课程设计宾馆客房信息管理系统

数据库课程设计宾馆客房信息管理系统(总34页)本页仅作为文档封面,使用时可以删除This document is for reference only-rar21year.March一、设计内容与设计要求1.设计内容:数据库系统原理的课程设计要求学生综合利用本课程的有关知识,在教师的指导下,利用特定的数据库设计环境,针对具体的问题,完成从系统的需求分析、数据库的概念设计、数据库的逻辑设计,到数据库实现等设计过程,最终实现一个较为完整的反映应用需求的数据库系统。
因此,在设计中,要求学生应该全面考虑各个设计环节以及它们之间的相互联系。
下面是各个设计阶段的具体内容。
⒈系统需求分析需求分析是数据库系统设计的一个重要的环节。
本阶段应该对整个应用情况作全面的、详细的调查,确定特定数据库应用环境下的设计目标,收集该应用环境下针对系统设计所需要的基础数据以及对这些数据的具体存储要求,从而确定用户的需求。
用户对数据库的需求包括:⑴处理需求。
即用户要完成什么处理功能等。
学生在设计中应根据具体的课题要求确定系统应该实现的功能,一些基本的功能通常是必须具备的,如用户的管理与维护,基本数据的维护,灵活的信息查询等。
⑵信息需求。
即在数据库中需要存储哪些数据。
学生应该根据具体的课题,认真分析有关的要求,确定本设计的信息需求。
⑶安全性和完整性功能。
实践中这是一个需要与用户不断交流才能逐步确定的需求。
本课程设计要求学生在自己的设计中能反映出基本的安全性和完整性功能。
本阶段的设计结果(即系统需求分析)应该在课程设计报告中进行详细描述,画出系统的数据流图,写出较为详细的数据字典,作为本课程设计的验收依据之一。
⒉数据库的概念设计数据库的概念设计是在需求分析的基础上,利用与用户双方都能理解的形式,设计出数据库的概念模型。
本课程设计要求学生采用E-R方法进行数据库的概念设计。
本设计阶段可分为:● 数据抽象。
即根据需求分析的结果,抽取出与本课程设计相关的特性。
原创宾馆管理系统课程设计报告

原创宾馆管理系统课程设计报告1. 引言宾馆管理系统是一种通过计算机技术来管理和优化宾馆运营的软件系统。
它能够帮助宾馆实现客房预订管理、入住退房管理、房间维护管理、财务管理等功能。
本文将介绍一个原创的宾馆管理系统的设计和实现过程。
2. 功能需求分析宾馆管理系统的功能需求主要包括以下几个方面:2.1 客房预订管理宾馆管理系统应该提供客房预订功能,包括查询房间是否可预订、预订房间、取消预订等。
用户可以通过输入日期和房间类型查询可预订的房间,选择房间后进行预订。
2.2 入住退房管理宾馆管理系统应该提供入住退房管理功能,包括登记入住、办理退房、查询入住房间信息等。
用户可以输入身份信息进行入住登记,系统会自动生成订单和房间号码,同时将入住信息保存到数据库中。
2.3 房间维护管理宾馆管理系统应该提供房间维护管理功能,包括维修房间、清洁房间、更换床单等。
系统管理员可以登录系统进行房间状态的管理和维护工作。
系统会记录房间维护的时间和维护人员信息。
2.4 财务管理宾馆管理系统应该提供财务管理功能,包括统计客房收入、查询财务报表、生成账单等。
系统会自动记录客房收入和支出等财务信息,并生成对应的财务报表供管理员查询和分析使用。
3. 系统设计3.1 技术选型本系统的设计和实现基于Web应用技术,采用了前后端分离的架构。
前端使用HTML、CSS和JavaScript进行开发,后端使用Java语言和Spring框架进行开发,数据库使用MySQL进行存储。
3.2 数据库设计系统使用MySQL数据库进行数据存储,设计了以下几个主要的数据库表:•房间表:记录了房间编号、类型、价格、状态等信息。
•客户表:记录了客户编号、姓名、身份证号等信息。
•订单表:记录了订单编号、客户编号、房间编号、入住日期、退房日期等信息。
•维护记录表:记录了维护记录编号、房间编号、维护日期、维护人员等信息。
•财务表:记录了财务编号、收入金额、支出金额、日期等信息。
数据库课程设计酒店管理信息系统

酒店管理信息系统系统平台: Windows 2000数据库服务器: MicrosoftSQL Server 2000开发工具: Visual Basic 6.0系统开发人员:⒈编写目地酒店在正常地运营中需要对客房资源、顾客信息、结算信息进行管理 , 利用宾馆管理信息系统及时了解各个环节中信息地变更, 有利于提高管理效率 . b5E2RGbCAP⒉系统功能分析系统开发地总体任务是实现宾馆各种信息地系统化、规范化和自动化.主要完成功能:●有关客房标准地制定、标准信息地输入 , 包括标准编号、标准名称、房间面积、床位数量、住房单价、是否有空调、电视机、电话以及单独卫生间等 . p1EanqFDPw●客房标准信息地修改、查询等.●客房基本信息地输入 , 包括客房编号、客房类型、客房位置、客房单价、备注等 .●客房基本信息地查询、修改 , 包括客房编号、客房类型、客房位置、客房单价、备注等 .●剩余客房信息地查询等 .●订房信息地输入 , 包括客房编号、客房种类、客房位置、客房单价、顾客姓名、顾客身份证号码、入住日期、折扣、备注信息等 . DXDiTa9E3d●订房信息地修改和查询, 包括客房编号、客房种类、客房位置、客房单价、顾客姓名、顾客身份证号码、入住日期、折扣、备注信息等 . RTCrpUDGiT●结算信息地输入 , 包括客房编号、客房种类、位置、客房单价、顾客姓名、顾客身份证号码、入住日期、折扣、结算日期、备注信息等 . 5PCzVD7HxA●结算信息地修改和查询 , 包括客房编号、客房种类、客房位置、客房单价、顾客姓名、顾客身份证号码、入住日期、折扣、结日期、备注信息等 . jLBHrnAILg⒊系统功能模块设计按结构化程序设计思想 , 分析得出如下系统功能模块图宾馆管理信息系统结订客算房房系信信信统息息息管管管管理理理理剩结结结订订订余设设算算算房房房客置置密用信信信信信信房客客码户息息息息息息信房房管管查修添查修添息信标理理询改加询改加查息准询客客客客客房房房房房信信信标标息息息准准查修添修添询改加改加xHAQX74J0X图Ⅰ系统功能模块图⒋数据库设计数据库设计步骤:●数据库需求分析●数据库概念结构设计●数据库逻辑结构设计①数据库需求分析分析调查有关宾馆管理信息需求地基础上得本系统所处理地数据流程客房标准设置客房登记基本信息输入基本信息录入客房信息管理顾客登记订房信息管理订房信息管理客房信息返回结算信息输入结算信息管理LDAYtRyKfE图Ⅱ 宾馆管理信息系统数据流程图针对一般宾馆管理信息系统地需求, 通过对宾馆管理过程地内容和流程分析,设计如下面所示地数据项和数据结构:Zzz6ZB2Ltk●客房标准信息 , 包括地数据项有:标准编号、标准名称、房间面积、床位数量、住房单价、是否有空调、电视、电话、单独卫生间等 . dvzfvkwMI1●客房信息 , 包括地数据项有:客房编号、客房种类、客房位置、客房单价、备注等 .●订房信息 , 包括地数据项有:订房编号、客房编号、客房种类、客房位置、客房备注信息、顾客姓名、顾客身份证号码、入住时间、折扣、备注等 . rqyn14ZNXI●结算信息 , 包括地数据项有:订房编号、客房编号、客房种类、客房位置、客房备注信息、顾客姓名、顾客身份证号码、入住时间、折扣、结算时间、备注等 . EmxvxOtOco②数据库概念结构设计本系统根据以上地设计规划出地实体有:客房标准信息实体、客房信息实体、订房信息实体、结算信息实体. 各个实体具体地描述E-R图如下:SixE2yXPq5客房标准信息实体标准编号客房单价标准名称床位数量客房标准信息实体E - R图客房信息实体客房标准客房单价客房编号客房位置客房信息实体E - R图订房信息实体客房信息折扣顾客信息入住时间订房信息实体E - R图结算信息实体客房信息结算金额顾客信息结算时间结算信息实体E - R图客房标准信息客房登记客房信息管理订房结算信息管理订房信息管理客房结算实体之间关系E - R图③数据库逻辑结构设计首先将宾馆管理信息系统地数据库概念结构转化为SQL 2000数据库系统所支持地实际数据模型, 即:数据库地逻辑结构 . 其各个表格地设计结果如下6ewMyirQFL列名数据类型可否为空说明Typeid Varchar NOT NULL标准编号Typename Varchar NOT NULL标准名称Area Numeric NULL房间面积Bednum Numeric NULL床位数量Haircondition Varchar NULL是否有空调Htelephone Varchar NULL是否有电话Htelevision Varchar NULL是否有电视Htoilet Varchar NULL是否有单独卫生间Price Numeric NULL单价Roomtype 客房标准信息表列名数据类型 可否为空 说明 roomNO Varchar NOT NULL 客房编号 Roomtype Varchar NOT NULL 客房种类 Roomposition Varchar NULL 客房位置RoompriceNumeric NULL 单价PutupVarchar NOT NULL 是否被预定RoommemoText NULL备注Rooms 客房信息表列名数据类型 可否为空 说 明 BooknoVarchar NOT NULL 订房编号 Customname Varchar NOT NULL 顾客姓名 CustomID Varchar NOT NULL 身份证号码 Roomno Varchar NOT NULL 客房编号 Indate Datetime NULL 入住日期Discount Numeric NULL折扣 Inmeno Text NULL 备注 Checkdate Datetime NULL 结算日期AmountNumeric NULL金额Bookin 订房信息表⒌数据库结构地实现利用 SQL 2000 数据库系统中地查询分析实现数据库地逻辑结构 , 其表格如下: 创建系统用户表格 user_Info CREATE TABLE [dbo].[user_Info1]([user_ID][char](10> COLLATE Chinese_PRC_CI_AS NOT NULL, kavU42VRUs [user_PWD] [char] (10> COLLATE Chinese_PRC_CI_AS NULL, y6v3ALoS89 [user_Des] [char](10> COLLATE Chinese_PRC_CI_AS NULL M2ub6vSTnP > ON [PRIMARY]创建客房标准信息表格 roomtype CREATE TABLE [dbo].[roomtype]([typeid][char](10> COLLATE Chinese_PRC_CI_AS NOT NULL, [typename][char](10> COLLATE Chinese_PRC_CI_AS NOT NULL, [area][numeric](5,0> NULL,0YujCfmUCweUts8ZQVRd [bednum][numeric](2,0> NULL, [haircondition][char](2> COLLATE Chinese_PRC_CI_ASNULL,sQsAEJkW5T[htelephone][char](2> COLLATE Chinese_PRC_CI_AS NULL, [htelevision][char](2> COLLATE Chinese_PRC_CI_AS NULL,[htoilet][char](2> COLLATE Chinese_PRC_CI_AS NULL, [price][numeric](10,2>NULL> ON [PRIMARY]GMsIasNXkATIrRGchYzg创建客房信息表格 roomsCREATE TABLE [dbo].[rooms]([roomNO][char](10> COLLATE Chinese_PRC_CI_AS NOT NULL, 7EqZcWLZNX [roomtype][char](10> COLLATE Chinese_PRC_CI_AS NOT NULL,lzq7IGf02E [roomposition][char](20> COLLATE Chinese_PRC_CI_AS NULL,zvpgeqJ1hk [roomprice][numeric](10,2> NULL,[putup][char](2> COLLATE Chinese_PRC_CI_AS NOT NULL, NrpoJac3v1[roommemo][text] COLLATE Chinese_PRC_CI_AS NULL>ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]创建订房信息表 bookin CREATETABLE [dbo].[bookin]([bookno][char](14> COLLATE Chinese_PRC_CI_AS NOT NULL,1nowfTG4KI[customname][char](10>COLLATE Chinese_PRC_CI_AS NOT NULL,fjnFLDa5Zo[customID][char](18> COLLATE Chinese_PRC_CI_AS NOT NULL,tfnNhnE6e5 [roomno][char](10> COLLATE Chinese_PRC_CI_AS NOT NULL,HbmVN777sL [indate][datetime] NULL,[discount][numeric](2,0> NULL,[inmemo][text] COLLATE Chinese_PRC_CI_AS NULL,[checkdate][datetime] NULL,[ammount][numeric](10,2> NULL> ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]⒍宾馆管理信息系统具体程序实现⑴创建公用模块Module1.bas添加公共数据操作函数 , 用以执行各种 SQL 语句 . 添加函数 ExecuteSQL, 代码如下:Public Function ExecuteSQL(ByValSQL As String,MsgString AsString>_ As ADODB.Recordset V7l4jRB8Hs‘执行 SQL语句 , 并返回记录集对象Dim cnn As ADODB.ConnectionDim rst As ADODB.RecordsetDim sTokens(> As String‘异常处理On Error GoTo ExecuteSQ L_Error ’‘用 Split函数产生一个包含各个子串地数组sTokens=Split(SQL>Set cnn=NEW ADODB.Connection‘打开连接cnn.Open ConnectStringIf InStr( “INSERT,DELETE,UPDATE”,UCase$(sTokens(0>>> Then83lcPA59W9Cnn.Execute SQLMsgString=sTokens(0>& ”query successful”ElseSet rst=NEW ADODO.Recordsetrst.Open Trim$(SQL>,cnn,adOpenKeyset,adLockOptimisticmZkklkzaaP rst.MoveLastget RecordCount‘返回记录集对象Set ExecuteSQL=rstMsgString= ”查询到” &rst.RecordCount& ”条记录”End IfExecuteSQL_Exit:Set rst=NothingSet cnn=NothingExit FunctionExecuteSQL_Error:MsgString= ”查询错误 : ”&Err.DescriptionResume ExecuteSQL_ExitEnd FunctionPublic Sub EnterToTab(Keyasc As Integer>‘判断是否为回车键If Keyasc=13 Then ‘ Keyasc 用来保存当前按键‘转换成 Tab 键SendKey s”{TAB}”End IfEnd sub‘添加全局变量 , 用来记录各个窗口地读写状态, 代码如下:Public flagTedit As Boolean ‘标示是否进入修改地窗体Public flagRedit As BooleanPublic flagBedit As BooleanPublic flagCedit As BooleanPublic gintCmode As IntegerPublic gintTmode As Integer’记录是添加还是修改状态,1 为添加 ,2 为修改Public gintRmode As IntegerPublic gintBmode As IntegerPublic flagSedit As Boolean⑵系统用户管理模块地创建用户管理模块主要实现:·用户登陆 .·添加用户 .·修改用户具体客房标准添加代码:Private Sub Form_Load(>‘载入窗体后,判断所处状态Dim intCount As IntegerDim MsgText As StringDim i As IntegerIf gintTmode=1 Then‘判断是否属于添加状态Me.Caption=Me.Caption& ”添加”For i=0 To 3Combo1(i>.AddItem”否”Combo1(i>.AddItem”是”Combo1(i>.ListIndex=0Next iElseIf gintTmode=2 Then‘判断是否处于修改状态Setmrc=ExecuteSql(txtSQL,MsgText>If mrc.EOF=false ThenWith mrcFor intCount=0 To 3txtItem(intCount>=.Fields(intCount>Next intCounttxtItem(4>=.Fileds(8>For i=0 To 3Combo1(i>.Additem ”否”Combo1(i>.Additem ”是”Combo1(i>.ListIndex=0Next iEnd WithtxtItem(0>.Enabled=FalseEnd IfMe.Caption=Me.caption& ”修改”End IfmblChang=FalseEnd SubPrivate Sub cmd_Click(>’用户输入内容完毕后, 单击 cmdSave 按钮触发Click 事件AVktR43bpwDim intCount As IntegerDim sMeg As StringDim MsgText As StringFor intCount=0 To 4‘判断是否输入内容If Trim(txtItem(intCount>&”” >=”” ThenSelect Case intCountCase 0sMeg=”标准编号”Case 1sMeg=”标准名称”Case 2sMeg=”房间面积”Case 3sMeg=”床位数量”Case 4sMeg=”床位单价”End SelectsMeg=sMeg&”不能为空 ! ”MsgBox sMeg,vbOkOnly+vbExclamation, ”警告”txtItem(intCount>.SetFocusExit SubEnd ifNext intCount ‘判断输入内容是否为数字 ForintCount=2 To 4If Not IsNumeric(Trim(txtItem(intCount>>> ThenSelect Case intCountCase 2sMeg=”房间面积”Case 3sMeg=”床位数量”Case 4sMeg=”床位单价”End SelectsMeg=sMeg&”请输入数字 ! ”MsgBox sMeg,vbOKOnly+vbExclamation, ”警告”txtItem(intCount>.SeFocusExit SubEnd IfNext intCountIf gintTmode=1 Then‘判断是否有相同ID记录txtSQL=”sel ect*from roomtype where typeid_ =’” &Trim(txtItem(0>>&”’” ORjBnOwcEdSet mrc=ExecuteSQL(txtSQL,MsgText>If mrc.EOF=False ThenMsgBox“已经存在此标准编号地记录! ”,vbOKOnly+vbExclamation, ”警告”txtItem(0>.SetFocusExit SubEnd IfMrc.CloseEnd IftxtSQL=”select* from roomtype where typeid<> ’” &Trim(txtItem(0>>& ”’andtypename=’” &Trim(txtItem(1>>& ”’”2MiJTy0dTTSet mrc=ExecuteSQL(txtSQL,MsgText>If mrc.EOF=False ThenMsgBox”已经存在相同客房标准地记录! ”,vbOKOnly+vbExclamation,“警告”txtItem(1>.SetfocusExit SubEnd IftxtSQL=”delete from roomtype where typeid= ’” &Trim(txtItem(0>>& ”’”‘删除已有记录gIiSpiue7ASet mrc=ExecuteSQL(txtSQL,MsgText>txtSQL=”select *from roottype ”‘添加新记录 Setmrc=ExecuteSQL(txtSQL,MsgText>mrc.AddNewFor intCount=0 To 3mrc.Fields(intCount>=Trim(txtItem(intCount>>Next intCountFor intCount=0 To 3mrc.Fields(intCount+4>=Trim(Combo1(intCount>>Next intCountmrc.Fields(8>=Trim(txtItem(4>>mrc.Update‘更新数据库mrc.Closeif gintTmode=1 Then‘判断是否属于添加状态MsgBox “添加纪录成功 ! ”,vbOKOnly+vbExclamtion, “添加记录”For intCount=0 To 4txtItem(intCount>= ”” ‘清除已经输入地内容Next intCountFor intCount=0 To 3Combo1(intCount>.ListIndex=0Next intCountmblChange=False’判断是否打开窗口if flagTedit ThenUnload frmRoomtypefrmRoomtype.txtSQL=“select *from roomtype”frmRoomtype.ShowEnd IfElseIf gintTmode=2 Then‘判断是否处于修改状态Unload MeIf flagTedit ThenUnload frmRoomtypeEndIffrmRoomtype.txtSQL= ”select *from roomtype”frmRoomtype.ShowEnd IfEnd SubPrivate Sub txtItem_GotFocus(Index As Int eger>’文本框获得焦点时触发该事件 , 即自动选中输入地内容 , 便于修改uEh0U1YfmhtxtItem(Index>.SelStart=0txtItem(Index>.SelLength=Len(txtItem(Index>>End SubPrivate Sub cmdExit_Click(>’单击按钮cmdExit取消添加信息If mblChange And cmdSave.Enabled ThenIf MsgBox(“保存当前记录地变化吗?”,vbOKCancel+vbExcl amation, ”警告”>=vbOK Then ‘保存IAg9qLsgBXCall cmdSave_ClickEnd IfEnd IfUnload MeEnd SubPrivate Sub txtItem_KeyDown(Index As Integer,KeyCode As Integer,Shift_ As Integer> ‘输入完内容 , 单击回车键将自动进入下一个文本框 , 触发文本框地 Keydown事件WwghWvVhPEEnterToTab KeyCodeEnd Sub⑶修改客房标准窗体地创建Private Sub From_Load(>ShowTitleShowDataflagTedit=TrueEnd SubPrivate Sub ShowTitle(>‘调用showTitle函数,显示表头Dim i As IntegerWith msgList.Cols=10.TextMatrix(0,1>=”标准编号”.TextMatrix(0,2>=”标准名称”.TextMatrix(0,3>=”房间面积”.TextMatrix(0,4 >=”床位数量”.TextMatrix(0,5 >=”是否有空调”.TextMatrix(0,6 >=”是否有电话”.TextMatrix(0,7 >=”是否有电视”.TextMatrix(0,8 >=”是否有卫生间”.TextMatrix(0,9 >=”房间单价”.FixedRows=1‘固定表头For i=0 To 9‘设置各列地对齐方式.ColAlignment(i>=0Next i.FillStyle=flexFillRepeat‘表头项居中.Col=0.Row=0.RowSel=1.ColSel=.Cols-1.CellAlignment=4.ColWidth(0>=300‘设置单元大小.ColWidth(1>=1000.ColWidth(2>=2000.ColWidth(3>=2000.ColWidth(4>=1000.ColWidth(5>=1000.ColWidth(6>=1000.ColWidth(7>=1000.ColWidth(8>=1000.ColWidth(9>=1000.Row=1End WithEnd SubPrivate Sub ShowData(> ‘调用 showData 函数 , 显示记录列表Dim i As IntegerSet mrc=ExecuteSQL(txtSQL,MsgText>‘根据需要设置SQL 语句 , 显示需要地记录 asfpsfpi4kWith msgList.Rows=1Do While Not mrc.EOF.Rows=Rows+1For i=1 To mrc.Fields.CountSelect Case mrc.Fields(i-1>.TypeCase adDBDate.TextMatrix(.Rows-1,i>=Format(mrc.Fields(i-1>&”” , ”yyyy -mm-dd”>ooeyYZTjj1Case Else.TextMatrix(.Rows-1,i>=mrc.Fields(i-1>&””End SelectNext iMrc.MoveNextLoopEnd Withmrc.CloseEnd SubPrivate Sub msgList_MouseUp(Button As Integer,Shift As Integer,x As Single,y As Single>‘选择记录 , 然后单击鼠标右键 , 触发MouseUp事件BkeGuInkxIIf Button=2 And Shift=0 ThenPopupMenu fMainFrom.menuRoomtypeEnd IfEnd SubPrivate Sub menuModifyroomtype_Click(>Dim intCount As IntegerIf flagTedit Then‘判断是否打开记录窗体If frmRoomtype.msgList.Rows>1 ThenfintTmode=2‘设置为修改状态intCount=frmRoomtype.msgList.Row‘记下选择记录frmRoomtype1.txtSQL= ”select*from roomtype where typeid ’”&Trim(frmRoomtype.msgList.TextMatrix(intCount,1>>& ”’”PgdO0sRlMofrmRoomtype1.ShowElseCall menuAddroomtype_ClickEnd IfElsefrmRoomtype.txtSQL= ”select*from roomtype ”frmRoomtype.ShowEnd IfEnd SubPrivate Sub From_Resize(>‘窗体变化时,调整标签和表格位置,使标签处于窗体地最上方 , 而表格始终处于标签下方3cdXwckm15If Me.WindowState<>vbMinimized And fMainFrom.WindowState<>vbMinimizedThen‘边界处理h8c52WOngMIf Me.Scaleheight<10*lblTitle.Height ThenExit SubEnd IfIf Me.ScaleWidth<lblTitle.Width+lblTitle.Width/2Then v4bdyGiousExit SubEnd IflblTitle.Top=lblTitle.Height ‘控制控件地位置lblTitle.Left=(Me.Width-lblTitle.Width>/2msgList.Top=lblTitle.Top+lblTitle.Height+lblTitle.Height/2J0bm4qMpJ9msgList.Width=Me.ScaleWidth-200msgList.Left=Me.ScaleLeft+100msgList.Height=Me.ScaleHeight-msgList.Top-200End IfEnd Sub⑷删除客房标准Private Sub menuDeleteroomtype_Click(>Dim txtSQL As StringDim intCount As IntegerDim mrc As ADODB.RecordsetDim MsgText AsString If flagTedit Then‘判断是否打开记录窗体If frmRoomtype.msgList.Rows>1 ThenIf MsgBox(“真地要删除这么?”, vbOKCancel+vbExclamation,条文件记录”警告”>=vbOKThen XVauA9grYPintCount=frmRoomtype.msgList.RowtxtSQL=”delete from roomtype wheretypeid ’” &Trim(frmR oomtype.msgList.TextMatrix(intCount,1>>& ”’”bR9C6TJscwSet mrc=ExecuteSQL(txtSQL,MsgText>Unload frmRoomtype‘关闭记录窗体frmRoomtype.txtSQL= ”select*from roomtype”‘重新选择所有记录frmRoomtype.ShowEnd IfEnd IfEnd IfEnd Sub⑸客房信息管理模块地创建客房信息管理模块主要实现如下功能:·添加客房信息·修改客房信息·删除客房信息·查询客房信息具体实现代码如下:Private Sub From_Load(>‘载入窗体时,自动添加客房信息种类Dim sSql As StringDim intCount As IntegerDim MsgText As StringDim mrcc As ADODB.RecordsetIf gintRmode=1 Then ‘判断是否处于添加状态Me.Caption=me.Caption& “添加”txtSQL=”select DISTINCT typename from roomtype ”Set mrc=ExecuteSQL(txtSQL,MsgText> If Not mrc.EOF ThenDo While Not mrc.EOFcboItem(0>.AddItem Trim(mrc.Fields(0>>mrc.MoveNextLoopcboItem(0>.ListIndex=0Else‘显示记录内容MsgBox “请先进行客房标准设置 ! ”,vbOKOnly+vbExclamation, “警告”cmdSave.Enabled=FalseExit SubEnd Ifmrc.CloseElseIf gintRmode=2 Then‘判断是否处于修改状态Set mrcc=ExecuteSQL(txtSQL,MsgText>‘设置SQL 语句显示当前选择记录pN9LBDdtrdIf mrcc.EOF=False ThenWith mrcctxtItem(0>=.Fields(0>For intCount=1 To 2If Not IsNull(.Fields(intCount+1>>Then‘ 判断内容是否为空txtItem(intCount>=.Fields(intCount+1>End IfNext intCounttxtItem(3>=.Fields(5>txtSQL=”select DISTINCT typename fromroomtype ”Set mrc=ExecuteSQL(txtSQL,MsgText>If Not mrc.EOF ThenDo While Not mrc.EOFcboItem(0>.AddItem Trim(mrc.Fields(0>>mrc.MoveNextLoopcboItem(0>.ListIndex=0ElseMsgBox“ 请先进行客房标准设置! ”,vbOKOnly+vbExclamation, “警告”cmdSave.Enabled=FalseExit SubEnd Ifmrc.CloseEnd WithEnd Ifmrcc.CloseMe.Caption=Me.Caption&“修改”End IfmblChange=FalseEnd SubPrivate Sub cmdSave_Click(>‘单击保存按钮触发事件Dim intCount As IntegerDim sMeg As StringDim mrcc As ADODB.RecordsetDim Msgtext As StringFor intCount=0 To 3If Trim(TxtItem(intCount>&”” >=””ThenSelect Case intCountCase 0sMeg=“客房编号”Case 1sMeg=“客房位置”End SelectsMeg=sMeg&“不能为空!”MsgBox sMeg,vbOKOnly+vbExclamation,“警告”txtItem(intCount>.SetFocusExit SubEnd IfNext intCountIf gintRmode=1 Then‘判断是否有重复记录txtSQL=”select*from rooms where roomNO=‘ ”&Trim(txtItem(0>>&”’” DJ8T7nHuGTSet mrc=ExecuteSQL(txtSQL,msgText>If mrc.EOF=False ThenMsgBox“已经存在此客房编号地记录!” ,vbOKOnly+vbExclamation, “警告”txtItem(0>.SetFocusExit SubEnd Ifmrc.CloseEnd IfIf gintRmode=2 Then‘判断是否处于修改状态txtSQL=”delete from rooms where roomNO=‘ ”&Trim(txtItem(0>>&”’” QF81D7bvUASet mrc=ExecuteSQL(txtSQL,MsgText>End IftxtSQL=”select*from rooms ”‘再加入新记录Set mrc=ExecuteSQL(txtSQL,MsgText>mrc.AddNew‘为数据库对象添加记录mrc.Fields(0>=Trim(txtItem(0>>mrc.Fields(1>=Trim(txtItem(0>>For intCount=1 To 2If Trim(txtItem(intCount>& ”” >=”” Thenmrc.Fields(intCount+1>=NullElsemrc.Fields(intCount+1>=Trim(txtItem(intCount>>End IfNext intCountmrc.Fields(4>=””mrc.Fields(5>=Trim(txtItem(3>>mrc.Updatemrc.CloseIf gintRmode=1 ThenFor intCount=0 To 3txtItem(intCount>=””Next intCountmblChange=FalseIf flagRedit ThenUnload frmRoomfrmRoom.txtSQL=”select*from rooms ”‘重新显示数据frmRoom.ShowEnd IfElseIf gintRmode=2 ThenUnload MeIf flagRedit ThenUnload frmRoomEnd IffrmRoom.txtSQL=”select*from rooms”frmRoom.ShowEnd IfEnd Sub·修改客房信息Private Sub menuModifyroom_Click(>‘选择修改房间信息,触menuModifyroom 地 Click事件,程序判断为修改状态后 , 首先删除原有记录 , 然后把新内容加入到数据库中4B7a9QFw9hDim intCount As IntegerIf flagRedit Then‘判断记录窗体是否打开If frmRoom.msgList.Rows>1 Then‘判断客房信息列表内容是否为空gintRmode=2‘设置为修改状态intCount=frmRoom.msgList.Row‘纪录当前记录位置frmRoom1.txtSQL=”select*from rooms whereroomNO=’” &Trim(frmRoom.msgList.TextMatrix(intCount,1>>&”’” ix6iFA8xoXfrmRoom1.ShowElseCall menuAddroom_Click‘添加记录End IfElsefrmRoom.txtSQL=”select*from rooms”frmRoom.ShowEnd IfEnd Sub·删除客房信息Private Sub menuDeleteroom_Click(>Dim txtSQL As StringDim intCount As IntegerDim mrc As ADODB.RecordsetDim MsgText As StringIf flagTedit ThenIf frmRoom.msgList.Rows>1 Then ‘判断客房信息列表内容是否为空 If MsgBox( “真地要删除这条文件记录么?” ,vbOKCancel+vbExclamation,“警告” >=vbOK Then wt6qbkCyDEintCount=frmRoom.msgList.Row‘记载当前记录位置txtSQL=”delete from rooms where roomNO=‘” &Trim(frmRoom.msgList.TextMatrix(intCount,1>&”’”Kp5zH46zRkSet mrc=ExecuteSQL(txtSQL,MsgText>‘执行删除操作Unload frmRoomfrmRoom.txtSQL=”select*from rooms ”frmRoom.ShowEnd IfEnd IfEnd IfEnd Sub·查询客房信息Private Sub From_Load(>‘载入窗体时,将自动加入所有记录地入库时间Dim i As IntegerDim j As IntegerDim sSql As StringDim txtSQL As StringDim MsgText As StringDim mrc As ADODB.Recordsettx tSQL=”select DISTINCT typename from roomtype ” ‘初始化客房种类Yl4HdOAA61Set mrc=ExecuteSQL(txtSQL,MsgText>If Not mrc.EOF ThenDo While Not mrc.EOFCombo1.AddItem Trim(mrc.Fields(0>>Mrc.MoveNextLoopCombo1.ListIndex=0ElseMsgBox “请先进行客房标准设置! ”,vbOKOnly+vbExclamation, ”警告”Exit SubEnd Ifmrc.CloseEnd SubPrivate Sub cmdOK_Click(>‘设置完查询内容和方式后,单击cmdOk按钮查询Dim sQSql As StringIf chkItem(0>.Value=vbChecked ThensQSql=”roomNO=’”&Trim(txtItem(0>& ””>&”’”End IfIf chkItem(1>.Value=vbChecked ThenIf Trim(sQSql&”” >=”” ThensQSql=”roomtype=’” &Trim(Combo1&”” >&”’”ElsesQSql=sQSql&”and roomtype= ’” &Trim(Combo1&”” >&”’”End IfEnd IfIf Trim(sQSql>=”” ThenMsgBox “请设置查询条件!” ,vbOKOnly+vbExclamation, “警告” Exit SubElseIf flagRedit ThenUnload frmRoomEnd IffrmRoom.txtSQL=”select*from rooms where ”&sQSqlfrmRoom.ShowEnd IfMe.HideEnd Sub⑹订房信息管理模块地创建订房信息管理模块主要实现如下功能:·查询剩余客房信息·添加订房信息·修改订房信息·删除订房信息·查询订房库信息具体实现代码如下:Private Sub From_Load(> ‘载入窗体时 , 程序将自动加入客房种类和客房单价Dim txtSQL As StringDim MsgText As StringDim mrc As ADODB.RecordsettxtSQL=”select distinct typename from roomtype”‘选择所有客房种类 ch4PJx4BlISet mrc=ExecuteSQL(txtSQL,MsgText>If Not mrc.EOF ThenDo While Not mrc.EOFCombo1(0>.AddItem mrc.Fields(0>mrc.MoveNextLoopEnd Ifmrc.ClosetxtSQL=”select distinct price from roomtype”Set mrc=ExecuteSQL(txtSQL,MsgText>If Not mrc.EOF ThenDo While Not mrc.EOFCombo1(1>.AddItem mrc.Fields(0>Combo1(2>.AddItem mrc.Fields(0>mrc.MoveNextLoopEnd Ifmrc.CloseEnd SubPrivate Sub cmdOK_Click(>Dim sQSql As StringIf chkItem(0>.Value=vbChecked ThensQSql=”roomtype=’” &Trim(Combo1(0>&”” >&”’” End ifIf chkItem(1>.Value=vbChecked ThenIf Trim(sQSql&”” >=”” ThenIf Trim(Combo1(1>&”” ><>”” AndTrim(Combo1(2>&”” ><>””qd3YfhxCzoThensQSql=”roomprice<= ’” &Trim(Combo1(1>&”” >&Androomprice >=’” &Trim(Combo1(2>&”” >”’”E836L11DO5ElseIf Trim(Combo1(1>&”” >=”” AndTrim(Combo1(2>&”” ><>”” Then S42ehLvE3MsQSql=”roomprice >= ’” &Trim(Combo1(2>&”” >&”’”ElseIf Trim(Combo1(1>&”” ><>”” And Trim(Combo1(2>&””=”” Then501nNvZFissQSql=”roomprice<= ’” &Trim(Combo1(1>&”” >&”’”End IfElseIf Trim(Combo1(1>&”” ><>”” AndTrim(Combo1(2>&”” ><>”” Then jW1viftGw9sQSql=sQSql&”androomprice>= ’” &Trim(Combo1(1>&”” >&”’ androomprice>=’” &Trim(Combo1(2>&”” >&”’” xS0DOYWHLPElseIf Trim(Combo1(1>&”” >=”” AndTrim(Combo1(2>&”” ><>””Then LOZMkIqI0w sQSql=sQSql&”androomprice>=’” &Trim(Combo1(2>&”” >&”’” ZKZUQsUJedElseIf Trim(Combo1(1>&”” ><>”” AndTrim(Combo1(2>&”” >=”” Then dGY2mcoKtTsQSql=sQSql&”androomprice<= ’” &Trim(Combo1(1>&”” >&”’”rCYbSWRLIAEnd IfEnd IfIf Trim(sQSql>=”” ThenMsgBox“请设置查询条件 ! ”,vbOKOnly+vbExclamation, “警告”Exit SubElseIf flagRedit ThenUnload frmRoomEnd IffrmRoom.txtSQL=”select*from rooms where”&sQSql&”andputup ”<>’y’”FyXjoFlMWhfrmRoom.ShowflagSedit=TrueEnd IfMe.HideEnd SubPrivate Sub From_Load(>‘添加订房信息,载入窗体时把所有未预定地客房信息加入其中TuWrUpPObXDim sSql As StringDim intCount As IntegerDim MsgText As StringIf flagSedit Then‘判断打开方式Set mrc=ExecuteSQL(txtSQL,MsgText>If Not mrc.EOF ThenFor intCount=0 To 3cboItem(intCount>.AddItem mrc.Fields(intCount>cboItem(intCount>.ListIndex=0Next intCounttxtItem(5>=mrc.Fields(5>End Ifmrc.ClosetxtNo=GetRkno(>gintBmode=1ElseIf gintBmode=1 ThenMe.Caption=Me.Caption&“添加”txtSQL=”select DISTINCT roomNO from rooms whereputup<>’y’”7qWAq9jPqESet mrc=ExecuteSQL(txtSQL.MsgText>If Not mrc.EOF ThenDo While Not mrc.EOFcboItem(0>.AddItem Trim(mrc.Fields(0>>mrc.MoveNextLoopElseMsgBox“请先进行客房登记!” ,vbOKOnly+vbExclamation,“警告”cmdSave.Enabled=FalseExit SubEnd Ifmrc.ClosetxtNo=GetRknoElseIf gintBmode=2 ThenSet mrc.ExecuteSQL(txtSQL,MsgText>If mrc.EOF ThenWith mrctxtNO=!booknoFor intCount=0 To 1If Not IsNull(.Fields(intCount+1>> ThentxtItem(intCount>=.Fields(intCount+1>End IfNext intCountcboItem(0>.AddItem !roomnocboItem(0>.ListIndex=0For intCount=2 To 4If Not IsNull(.Fields(intCount+2>> ThentxtItem(intCount>=.Fields(intCount+2>End IfNext intCountEnd WithEnd Ifmrc.CloseMe.Caption=Me.Caption&“修改”txtSQL=”select*from rooms where roomNO=’”&Trim(cboItem(0>>& ”’”llVIWTNQFkSet mrc=ExecuteSQL(txtSQL,MsgText>If Not mrc.EOF ThenFor intCount=1 To 3cboItem(intCount>.AddItem mrc.Fields(intCount>cboItem(intCount>.ListIndex=0Next intCounttxtItem(5>=mrc.Fields(5>End Ifmrc.CloseEnd IfEnd IfmblChange=FalseEnd SubPrivate Sub cmdSave_Click(>‘添加记录到数据库中Dim intCount As IntegerDim sMeg As StringDim mrcc As ADODB.RecordsetDim MsgText As StringFor intCount=0 To 3‘判断输入内容是否为空If Trim(txtItem(intCount>&”” >=””ThenSelect Case intCountCase 0sMeg=“顾客姓名”Case 1sMeg=“身份证号码”Case 2sMeg=“折扣”Case 3sMeg=“入住时间”End SelectsMeg=sMeg&“不能为空 ! ”MsgBox sMeg,vbOKOnly+vbExclamation, “警告”txtItem(intCount>.SetFocusExit SubEnd IfNext intCountFor intCount=0 To 3If Trim(vboItem(intCount>&”” >=”” ThenSelect Case intCountCase 0sMeg=“客房编号”Case 1sMeg=“客房种类”Case 2sMeg=“客房位置”Case 3sMeg=“客房单价”End SelectsMeg=sMeg&“不能为空!”MsgBox sMeg,vbOKOnly+vbExclamation,“警告”cboItem(intCount>.SetFocusExit SubEnd IfNext intCountIf IsDate(txtItem(2>> ThentxtItem(2>=Format(txtItem(2>,”yyyy -mm-dd”>ElseMsgBox“入库时间应输入日期(yyyy-mm-dd>! ”,vbOKOnly+vbExclamation,”警告” yhUQsDgRT1txtItem(2>.SetFocusExit SubEnd IfFor intCount=1 To 3 Step 2If Not IsNumeric(txtItem(intCount>> ThenMsgBox“请输入数字” ,vbOKOnly+vbExclamation, “警告”txtItem(intCount>.SetFocusExit SubEnd IfNext intCountIf gintBmode =2 Thenwhere txtS QL=”delete from bookingbookno=’” &Trim(txtNo>& ”’”MdUZYnKS8ISet mrcc=ExecuteSQL(txtSQL,MsgText>End IftxtSQL=”select*from booking”Set mrcc=ExecuteSQL(txtSQL,MsgText>mrcc.AddNewmrcc.Fields(0>=txtNOFor intCount=0 To 1mrcc.Fields(intCount+1>=txtItem(intText>Next intCountmrcc.Fields(3>=cboItem(0>For intCount=2 To 4mrcc.Fields(intCount+2>=txtItem(intCount>Next intCountmrcc.Fields(8>=0mrcc.Updatemrcc.ClosetxtSQL=”select*from rooms where roomNO=’”&Trim(vboItem(0>>& ”’”09T7t6eTnoSet mrcc=ExecuteSQL(txtSQL,MsgText>If Not mrcc.EOf Thenmrcc!putup= ”y”End Ifmrcc.Updatemrcc.CloseIf gintBmode=1 ThenMsgBox“添加订房信息成功 ! ”,vbOKOnly+vbExclamation, “添加订房消息”Unload MeIf flagBedit ThenUnload frmBookinEnd IffrmBookin.txtSQL= ”selectbookno,customname,customID,roomno,indate,discount,inmemo from booking whereamount=’0’”e5TfZQIUB5frmBookin.ShowElseMsgBox “修改订房信息成功 ! ”,vbOKOnly+vbExclamation, “修改订房信息”Unload MeIf flagBedit ThenUnload frmBookinEnd IffrmBookin.txtSQL= ”selectbookno,customname,customID,roomno,indate,discount,inmemo from booking where amount=’0’”s1SovAcVQMfrmBookin.ShowEnd IfEnd Sub⑺结算信息管理模块地创建结算信息管理模块主要实现如下功能:·添加结算信息·修改结算信息·查询结算信息具体实现代码如下:Private Sub From_Load(>‘窗体载入时,自动加入所有未结算客房信息Dim sSql As StringDim intCount As IntegerDim MsgText As StringIf gintCmode=1 Then ‘判断是否处于添加状态Me.Caption=Me.Caption& “添加”txtSQL=”select DISTINCT roomno from booking whereamount=’0’”‘初始化客房编号 , 选择所有未结算客房编号GXRw1kFW5s Set mrc=ExecuteSQL(txtSQL,MsgText>If Not mrc.EOF ThenDo While Not mrc.EOFcboItem(0>.AddItem Trim(mrc!roomno>mrc.MoveNextLoopElseMsgBox“没有顾客入住 ! ”,vbOKOnly+vbExclamation, cmdSave.Enabled=FalseExit SubEnd Ifmrc.CloseElseIf gintCmode=2 Then‘判断是否处于修改状态Set mrc=ExecuteSQL(txtSQL,MsgText>If mrc.EOF=False ThenWith mrctxtNo =mrc.Fields(0>For intCount=0 To 1txtItem(intCount>=.Fields(intCount+1>Next intCountcboItem(0>.AddItem.fields(3>cboItem(0>.ListIndex=0For intCount=2 To 3If Not IsNull(.Fields(intCount+2>> ThentxtItem(intCount>=.Fields(intCount+2>End IfNext intCounttxtItem(5>=.Fields(6>txtItem(4>=.Fields(7>End WithEnd Ifmrc.ClosetxtSQL=”select*from rooms “警告”whereroomNO=’” &cboItem(0>&”’”UTREx49Xj9 Set mrc=ExecuteSQL(txtSQL,MsgText>If mrc.EOF=False ThenWith mrcFor intCount=1 To 3cboItem(intCount>.AddItem.Fields(intCount>cboItem(intCount>.ListIndex=0Next intCountEnd WithEnd If。
宾馆管理系统数据库课程设计

宾馆管理系统数据库课程设计1. 引言宾馆管理系统是一种将计算机技术应用于宾馆管理的智能化系统。
它旨在提高宾馆服务质量和效率,简化宾馆工作流程,满足宾馆管理人员的日常运营和决策需求。
本文档主要介绍了宾馆管理系统数据库的课程设计。
2. 数据库设计2.1 实体宾馆管理系统中的主要实体包括:宾馆、客房、客户、员工和订单。
每个实体都有一组属性用于描述其特征和属性。
•宾馆:宾馆ID、宾馆名称、宾馆地址、联系电话等。
•客房:客房ID、房间号、客房类型、价格等。
•客户:客户ID、姓名、身份证号、联系电话等。
•员工:员工ID、姓名、职位、联系电话等。
•订单:订单ID、客户ID、客房ID、入住日期、退房日期等。
2.2 关系通过分析宾馆管理系统的需求,可以确定以下关系:•宾馆与客房之间的关系:一个宾馆可以有多个客房,一个客房只属于一个宾馆。
宾馆和客房之间是一对多关系。
•宾馆与员工之间的关系:一个宾馆可以有多个员工,一个员工只属于一个宾馆。
宾馆和员工之间是一对多关系。
•客房与订单之间的关系:一个客房可以有多个订单,一个订单只属于一个客房。
客房和订单之间是一对多关系。
•客户与订单之间的关系:一个客户可以有多个订单,一个订单只属于一个客户。
客户和订单之间是一对多关系。
2.3 数据表设计基于上述实体和关系,可以设计以下数据表:•宾馆表(hotel)–宾馆ID(hotel_id):主键–宾馆名称(hotel_name)–宾馆地址(hotel_address)–联系电话(hotel_phone)•客房表(room)–客房ID(room_id):主键–宾馆ID(hotel_id):外键,关联宾馆表–房间号(room_number)–客房类型(room_type)–价格(room_price)•客户表(customer)–客户ID(customer_id):主键–姓名(customer_name)–身份证号(customer_idcard)–联系电话(customer_phone)•员工表(employee)–员工ID(employee_id):主键–姓名(employee_name)–职位(employee_position)–联系电话(employee_phone)–宾馆ID(hotel_id):外键,关联宾馆表•订单表(order)–订单ID(order_id):主键–客户ID(customer_id):外键,关联客户表–客房ID(room_id):外键,关联客房表–入住日期(checkin_date)–退房日期(checkout_date)3. 数据库操作宾馆管理系统需要支持以下数据库操作:•添加数据:可以向宾馆、客房、客户、员工和订单表中添加数据,如插入新的宾馆、客房、客户、员工和订单记录。
数据库原理酒店管理系统设计课程设计报告

数据库管理系统(DBMS)是提供数据存储、访问、定义和 管理功能的软件系统,如MySQL、Oracle等。
数据库设计原则
概念设计
根据需求分析结果,设计数据库的概念模 型,包括实体、属性、关系和约束等。
需求分析
在设计数据库之前,需要对酒店管 理系统的需求进行详细分析,包括 功能需求、数据需求和性能需求等
数据库设计
根据需求分析,设计酒店管 理系统数据库,包括客房、 客人、员工、预订等表,并 定义表之间的关系。
功能模块实现
按照系统设计,逐步实现各 个功能模块,包括客房管理 、客人管理、员工管理、预 订管理等。
界面设计与实现
设计简洁、直观的用户界面 ,并实现与后端的交互。
系统测试方法
黑盒测试
通过输入测试用例,检查系统输出是否符合预期 结果,验证系统功能的正确性。
实现财务报表生成 、财务分析等功能 。
前台接待模块
实现客人入住登记 、离店结算等功能 。
餐饮管理模块
实现餐厅预订、点 餐、结账等功能。
系统管理模块
实现用户管理、权 限管理、日志管理 等功能。
05
系统实现与测试
系统实现过程
系统架构搭建
采用B/S架构,前端使用 HTML、CSS、JavaScript等 技术,后端使用Java语言, 数据库采用MySQL。
。
A
B
C
D
物理设计
确定数据库的物理存储结构,包括数据的 存储方式、存储设备的选择和配置等。
逻辑设计
将概念模型转换为数据库的逻辑模型,包 括表、字段、索引和视图等数据库对象的 定义。
数据库在酒店管理系统中的作用
数据存储
数据库用于存储酒店管理系统中的各种数 据,如客人信息、房间信息、预订信息、
宾馆管理系统课程设计报告

宾馆管理系统课程设计报告1. 引言宾馆管理系统是一个针对宾馆业务管理的软件系统。
宾馆作为一种特殊的服务业,需要对客房预订、客户入住、客户结账、房间管理等一系列业务进行管理和处理。
本文档将详细介绍宾馆管理系统的课程设计报告,包括系统需求分析、系统设计、系统实现和系统测试。
2. 系统需求分析宾馆管理系统的主要需求包括以下几个方面:2.1 客房管理宾馆管理系统需要实现客房的管理和预订功能。
包括客房信息的录入、查询、修改和删除,以及客房的预订和取消预订。
2.2 客户管理宾馆管理系统需要实现客户的管理功能。
包括客户信息的录入、查询、修改和删除,以及客户入住和退房的登记。
2.3 订单管理宾馆管理系统需要实现订单的管理功能。
包括订单的录入、查询、修改和删除,以及订单的结账和发票打印。
2.4 报表统计宾馆管理系统需要提供报表统计功能。
包括客房入住率、客户结账金额、客户退房情况等报表的生成和展示。
3. 系统设计宾馆管理系统的设计主要包括以下几个模块:3.1 数据库设计根据系统需求分析,设计宾馆管理系统的数据库结构。
包括客房表、客户表、订单表等相关表的设计和字段定义。
3.2 用户界面设计设计宾馆管理系统的用户界面,包括客房查询界面、客户查询界面、订单管理界面等。
要求界面美观易用,功能清晰明确。
3.3 业务逻辑设计设计宾馆管理系统的业务逻辑,包括客房预订和取消、客户入住和退房、订单结账等业务的处理过程。
要求逻辑严谨、流程清晰。
4. 系统实现宾馆管理系统的实现主要涉及以下几个方面:4.1 系统框架搭建选择适合的开发框架,搭建宾馆管理系统的开发环境。
包括安装配置开发工具、创建项目结构等。
4.2 数据库操作实现根据系统设计中的数据库结构,使用编程语言对数据库进行操作,实现客房信息的录入、查询、修改和删除,以及客户信息的录入、查询、修改和删除等功能。
4.3 用户界面实现根据系统设计中的用户界面设计,使用前端技术实现界面的展示和交互。
宾馆客房管理系统数据库设计报告(精选五篇)

宾馆客房管理系统数据库设计报告(精选五篇)第一篇:宾馆客房管理系统数据库设计报告宾馆客房管理系统数据库设计报告摘要:本系统是宾馆客房管理系统,该报告主要介绍了数据库的设计,建立,主要功能的实现。
数据库系统包括员工管理、客房管理、顾客管理几个大块。
主要实现了登记功能,预订功能,多种方法查询顾客功能,查看客房状态功能,操作人员对系统的修改功能,以及结账报表功能。
一、需求分析(1)具有方便的登记、结账功能,以及预订客房的功能,能够支持团体登记和团体结账。
(2)能快速、准确地了解宾馆内的客房状态,以方便管理者决策。
(3)提供多种手段查询客人的信息。
(4)具备一定的维护手段,有一定权利的操作人员在密码的支持下才可以更改房价、房间类型、增减客房。
(5)完善的结账报表系统。
二、E-R关系图三、关系表本系统有八个表,分别是职工信息表(staffinfo)、顾客信息表(custmerinfo)、经理信息表(managerinfo)、客房信息表(roominfo)、客房状态表(roomstatus)、入住表(checkin)、退房表(checkout)、结账订单表(orderinfo)。
1,职工信息表(staffinfo)2,顾客信息表(custmerinfo)3,经理信息表(managerinfo)4,客房信息表(roominfo)5,客房状态表(roomstatus)6,入住表(checkin)7,退房表(checkout)8,结账订单表(orderinfo)四、范式分析本系统所有的表均为BCNF,职工和经理表由各自的工作编号为主码,并且可以决定其他所有属性,顾客表由身份证号做为主码,同理,客房的房间号可以决定其他所有属性。
五、功能分析 1,登记功能本系统采用存储过程实现登记功能,顾客前来预订客房,由工作人员调用存储过程向顾客表中插入该顾客信息,完成登记。
create procedure register@身份证号 varchar(20),@姓名 varchar(10),@性别 char(5),@电话 char(15), char(10)asinsert into custmerinfovalues(@身份证号,@姓名,@性别,@电话,@员工编号)@员工编号2,预订功能采用存储过程实现,由工作人员调用存储过程,在入住表中插入相应信息,并且设计触发器,在预定的同时在客房状态表中修改客房状态为“已入住”。
宾馆信息管理系统实验报告

目录一、系统开发平台 (2)二、数据库规划 (3)2.1 任务陈述 (3)2.2 任务目标 (3)3.1 系统边界.......................................... 错误!未定义书签。
3.2 用户视图 (6)四、需求分析 (7)4.1 用户需求说明 (7)4.1.1 数据需求 .....................................................4.1.2 事务需求 (8)4.2 系统需求说明 (9)五、数据库逻辑设计 ....................................... 错误!未定义书签。
5.1 ER图 ..............................................................5.3 关系表.............................................................六、数据库物理设计 ....................................... 错误!未定义书签。
6.1 索引 (25)6.2 视图 (25)6.3 安全机制 (26)6.4 其他 (27)七、应用程序设计 ......................................... 错误!未定义书签。
7.1 功能模块 (28)7.2 界面设计 (27)八、总结 ................................................. 错误!未定义书签。
附. 参考文献 ............................................. 错误!未定义书签。
一、系统开发平台题目、开发工具、数据库、操作系统等。
题目:宾馆信息管理系统开发工具:PowerBuilder数据库:SQL Sever操作系统:Windows XpPB语言的简介:PB使用的编程语言叫做PowerScript,它也是一种高级的,结构化的编程语言。
宾馆信息管理系统数据库课程设计报告

由于酒店管理系统是一个典型的数据库应用系统,因而选择一个良好的DBMS是系统实现的另一个重要环节。DBMS访问数据库。一般来说现代的DBMS具备以下几个功能:
(1)事务的恢复功能:为尽可能减少由于故障而引起的数据库数据失效的损失,现代的DBMS通常具备恢复功能。
(2)完整性约束检查:由于数据库中的数据是持久和共享的,其正确性十分重要,
为保证数据的正确性,DBMS提供对数据库数据的语法和语义的检查,数据在语义上的约束称为完整性约束。
(3)访问控制:并不是任何用户可以不加限制的访问任何数据库中的数据,DBMS
应有控制用户访问权限的功能,即所谓的访问控制功能,访问控制不但可以限制用户的访问范围,而且可以限制用户可进行的操作。
(4)数据目录管理:数据库中保留的是持久和共享的数据,对数据的定义应不同于一般的程序设计语言,应独立于应用程序,长期保留在数据库中,这就构成了数据目录,数据目录的管理是DBMS的基本功能。
取消预订订单(直接删除预订订单,恢复房间的可用状态)
将预订订单直接转为入住(省去了再次生成入住订单的程序)
房间查询(可按照房间号、房间类型、房间状态查询)
客户查询(可按照客户姓名、客户身份证号、入住类型查询)
入住客户中途换房(只能换同种类型房间,消费金额不变)
入住客户正常退房(根据入住时间计算消费金额,最后客户应缴费用为总费用与已交押金之差)
(3)管理员功能:除了前台接待的功能之外,还包括
房间信息设定及修改(包括客房类型,客房分机号,楼层,备注)
个人信息修改(包括个人密码,联系方式,住址)
增加客房类型(包括类型号,单价,床位数,房间设施,面积等)
增加客房信息(包括房间号,房间类型,房间分机,楼层,备注)
数据库课程设计之宾馆住宿管理系统

宾馆住宿管理系统本系统针对宾馆住宿的一般管理模式,采用基于计算机网络技术的宾馆管理解决方案,按照宾馆的现代化管理要求设计,实现对宾馆住宿的接待,客房,订房,收支情况,电话等服务设施的全面全方位计算机管理。
目标在于提高宾馆营业体系的作业效率,提高服务的客户满意度,加强宾馆的市场竞争力,树立良好的企业形象.通过计算机管理,一方面提供给客户快捷准确可靠的服务,另一方面提高宾馆自身的管理水平,及时准确获取营业信息,辅助对市场需求变化的决策.第一章系统概述1.1系统开发的背景和意义随着我国经济的迅速发展,人们的生活水平有了显著的提高,假日经济和旅游经济已成为人们消费的热点。
各地也把旅游业当作本地经济发展的重要经济支柱之一,从而促进了宾馆酒店业的快速发展。
同时,随着宾馆酒店越来越多,人们的要求越来越高,宾馆酒店业的竞争也愈来愈激烈。
如何在激烈的竞争中生从发展,是每一个宾馆酒店必须面临的问题。
对宾馆的经营状况起决定作用的是宾馆的服务管理水平。
如何利用先进的管理手段、提高宾馆的管理水平,以成为宾馆酒店业发展的当务之急。
面对信息时代的机遇和挑战,利用科技手段提高企业管理水平是企业管理无疑的一条行之有效的途径。
现在的宾馆行业已经发生拉巨大变化,已不仅是提供给人们一个吃住行的简单场所,所以,将计算机管理引入宾馆的管理体系中,无疑对宾馆的服务水平更上一层楼提供了一种有利的支持。
虽然计算机管理并不是宾馆管理走向成功的关键元素,但它可以最大限度地发挥准确、快捷、高效等作用,对宾馆的服务管理提供强有力的支持。
因此,采用全新的计算机网络和宾馆管理系统,已成为提高宾馆的管理效率、改善服务的水准的重要手段之一。
在某种意义上,宾馆客房管理方面的信息话已成为现代化宾馆的重要标志。
1.2系统所要实现功能该系统应充分利用信息技术提高宾馆客房的管理水平、服务水平。
酒店客房管理系统要实现客房住宿的登记、宿费提醒、追加押金、调房登记、退房结帐、查询统计等功能。
某宾馆客房管理系统——数据库课程设计报告

数据库原理课程设计报告设计题目某宾馆客房管理系统专业班级学号学生姓名起止日期年月日至月1 日摘要宾馆客房管理系统是对宾馆管理的现代化、网络化管理手段,逐步摆脱宾馆管理的人工管理方式,拓展经营空间,降低运营成本,提高管理和决策效率而开发的。
宾馆客房管理系统是宾馆经营管理中不可缺少的部分它的容对于经营的决策者和管理者来说都至关重要,所以客房管理系统、信息管理系统应该能够为用户提供充足的信息和快捷的查询手段。
但一直以来人们使用传统人工的方式管理文件档案。
这种管理方式存在着许多弊端如:效率低、保密性差容易出现差错等。
且对于查询空房间及已定房间等极为不方便。
在当今时代,这些完全可以改用计算机来代替人的手工操作。
作为计算机及网络应用的一部分使用计算机对客房信息进行管理,具有手工管理所无法比拟的优点。
例如:检索迅速、查找方便、可靠性高、存储量大、保密性好、寿命长、成本低等。
这些优点能够极大地提高客房经营管理的效率。
也是企业的科学化、正规化管理与世界接轨的重要条件。
且办事效率也是决定收入的一个关键因素。
宾馆客房管理系统主要包括前台管理系统和后台管理系统两大部分,基本包含了宾馆主要业务部门,初步实现了对顾客服务和进行财务核算所需要的各个功能。
它包括客户信息管理、客房信息管理、入住和退房管理、客房类型管理、费用管理、价目信息管理等6大功能模块,并提供了对各功能模块的查询和更新功能。
其中客户信息管理、入住和退房管理是系统开发的重点。
本系统由问题描述、系统需求分析、概念设计、逻辑设计、物理结构设计、触发器设计、存储过程设计、视图设计、数据库实施和维护组成。
目录1.问题描述 (1)1.1背景 (1)1.2编写目的 (1)1.3功能要求 (1)2.可行性分析 (1)3.需求分析 (2)3.1需求分析 (2)4系统概要设计 (3)4.1数据流图 (3)4.2数据字典 (7)5.概念结构设计 (8)5.1E-R图 (8)5.2实体及属性的定义 (9)6.逻辑结构设计 (11)7.物理结构设计 (12)8.触发器设计 (12)9.数据库的实施和维护 (13)10.结束语 (15)1.问题描述1.1要求某宾馆客房管理系统实现客房类型、价目信息、客房信息的管理;实现客户信息的管理;实现入住和退房管理;实现费用管理;创建触发器,实现入住和退房时自动修改客房的状态;创建存储过程统计某段时间各种类型的客房的入住时间合计和费用合计;创建视图查询某一时刻没有入住的房间信息;建立数据库相关表之间的参照完整性约束。
数据库课程设计宾馆信息管理系统

数据库课程设计报告宾馆信息管理系统数据库课程设计报告-------宾馆信息管理系统计算机科学与技术学院 08 级电子商务专业一、系统开发平台题目:酒店信息管理预订系统开发语言:Java Eclipse /netbeans后台数据库管理系统:SQL Server 2000 操作系统:windows xp二、数据库规划2.1 任务陈述引言客房管理系统是典型的信息管理系统的一部份,而且是必不可少的一部份。
其开发主要包括后台数据库的建立和维护以及前端应用程序的开发两个方面。
对于前者要求建立起简洁且资料一致性和完整性强、资料安全性好的数据库。
而对于后者则要求应用程序功能完备,易使用等特点。
酒店客房管理系统的内容对于经营的决策者和管理者来说都至关重要,所以客房管理系统、信息管理系统应该能够为用户提供充足的信息和快捷的查询手段。
但一直以来人们使用传统人工的方式管理文件档案,这种管理方式存在着许多弊端,如:效率低、保密性差,容易出现差错等,且对于查询空房间及已定房间等极为不方便。
在当今时代,这些完全可以改用计算机来代替人的手工操作。
作为计算机及网络应用的一部分,使用计算机对客房信息进行管理,具有手工管理所无法比拟的优点。
例如:检索迅速、查找方便、可靠性高、存储量大、保密性好、寿命长、成本低等。
这些优点能够极大地提高客房经营管理的效率,也是企业的科学化、正规化管理,与世界接轨的重要条件。
且办事效率也是决定收入的一个关键因素。
因此,我选择的酒店客房管理系统设计,力求开发出一套界面友好,功能强大,使用简单的适用于各大、中、小规模的酒店客房的管理系统。
同时也是一款完全适合宾馆或旅馆酒店客房管理傻瓜式日常业务管理的软件。
酒店系统由前台和后台管理两个部分组成。
前台作为与前台服务员直接交互的可视化界面,由于使用方便,能将系统的各个功能提供给他们,以帮助服务员进行客房管理。
前台在考虑功能实现的同时,也考虑了操作的简洁和方便性,目的是让大多数客户能够轻松地享受电子商务给他们带来的便利。
数据库课程设计报告-宾馆信息管理系统课程设计报告

数据库课程设计报告-----宾馆信息管理系统学院:软件学院专业:软件工程班级:2014级软件3班姓名:学号:任课教师:助教老师:目录一、开发平台 (4)1.1 数据库: MySQL: (4)1.2 操作系统: (4)1.3 开发工具: (4)1.4 整个系统采用C/S架构 (4)二、数据库规划 (4)2.1 任务陈述 (4)2.2 任务目标 (5)三、系统定义 (5)3.1 系统边界 (5)3.2 用户视图 (5)3.2.1 酒店前台视图 (5)3.2.2 数据库系统多用户视图 (6)3.3 系统模型图 (6)四、需求分析 (7)4.1 用户需求说明 (7)4.1.1 数据需求 (7)4.1.2 事务需求 (7)4.2 系统需求说明 (8)4.2.1 软件环境 (8)4.2.2 硬件环境 (8)4.2.3 初始数据库大小 (8)4.2.4 数据库增长速度 (9)4.2.5记录查找的类型和平均数量 (9)4.2.6性能 (9)4.2.7安全性 (9)五、数据库逻辑设计 (9)5.1 ER图 (10)5.2 数据字典 (10)5.2.1实体和联系属性: (10)5.2.2属性描述: (10)六、数据库物理设计 (12)6.1 索引 (12)6.2 安全机制 (12)6.2.1系统安全 (12)6.2.2数据安全 (12)七、应用程序设计 (13)7.1 功能模块 (13)7.1.1 换房 (13)7.1.2 登记入住 (13)7.1.3 查看预定 (13)7.1.4 预订客户入住 (13)7.1.5 更新房态功能 (14)7.1.6 结账功能 (14)7.1.7 显示会员及添加会员功能 (14)7.2 界面设计 (14)7.2.1 登入界面 (14)7.2.2 系统主界面 (15).2.3 预定界面 (15)7.2.4 预订信息界面 (16)7.2.5 预定入住界面 (16)7.2.6 客人登记界面 (16)7.2.7 换房界面 (17)7.2.8 结账界面 (18)7.2.9 会员制度及会员信息界面 (18)7.2.10 本店会员界面 (19)7.2.11 会员办理界面 (19)7.3 重要事务代码 (20)7.3.1 入住代码 (20)7.3.2 更换房间代码 (27)八、测试和运行 (33)8.1 房间的个数的测试 (33)8.2 系统运行bug测试 (33)8.3 客户端的数量 (33)九、总结 (33)9.1 课设总结 (33)9.2 系统优点 (34)9.3 系统不足 (34)9.4 经验与收获 (34)一、开发平台1.1 数据库: MySQL:MySQL数据库是目前最流行的关系型数据库,其体积小、速度快,使用的SQL语言也是用于访问数据库的最常用语言,一般的中小型系统都使用MySQL进行开发。
宾馆信息管理系统课程设计报告(大一)

哈尔滨理工大学软件学院课程设计报告课程设计 C++课程设计题目宾馆信息管理系统班级学生学号指导教师1.管理系统的功能说明a)密码登录验证访问。
b)浏览宾馆内部各房间信息。
c)添加新房间(支持重复添加)。
d)修改已存在的房间信息(支持重复修改)。
e)查询房间数据(按房间号、容量)(支持重复查询)。
f)添加自定义对结果排序显示功能。
g)退出系统及一些基本的用户友好的程序设计功能(各种错误处理)。
2.存储数据的描述在类定义中有以下成员:实现上述功能的成员函数接口public:Hotel();virtual ~Hotel();Hotel(int n,int v,int l,int p,int u):RoomNum(n),Capacity(v),Level(l),Price(p),used(u) {}void Look_through();void Reset_room(int x);void Show_room();friend void menu();friend void quit();friend void Init_room();friend Hotel Add_room();friend void Query(int n,int total);私有数据表示:private:int RoomNum; 房间号int Capacity; 房间容量char Level; 房间等级int Price; 房间价格int used; 是否预定static int total; 静态常量用来跟踪总房间数目信息3.概要设计说明书在该宾馆信息管理系统的设计中,根据功能要求抽象出类成员函数,并采用对象数组存储房间,用一个Hotel类封装起来。
通过友元函数访问私有数据从而实现信息管理系统的功能。
在运行过程中string password(string co) 实现了加密函数实现密码登陆。
void Hotel::Look_through()支持单个房间浏览,Hotel Add_room()实现了新房间的重复添加功能,void Hotel::Reset_room(int x) 实现了房间信息连续重置功能,void Query(int n,int total)函数实现了支持重复查询房间并允许自定义房间号和价格排序显示的功能,void quit() 退出系统登录功能。
宾馆信息管理系统实验报告

宾馆信息管理系统实验报告一、实验目的:通过设计和实现一个宾馆信息管理系统,掌握数据库设计、程序编写和软件测试等相关知识和技能。
二、实验内容:1.根据需求分析,设计数据库模型,包括宾馆、房间、客户等相关表的结构和关系。
2.构建宾馆信息管理系统的用户界面,包括登录界面和主界面。
3.实现宾馆基本信息的增、删、改、查功能。
4.实现房间管理功能,包括房间状态的查询和修改。
5.实现客户信息的管理功能,包括客户的入住和退房操作。
6.进行系统测试,确保系统的功能和性能符合需求。
三、实验过程:1.数据库设计:2.用户界面设计:使用Java Swing库设计了宾馆信息管理系统的用户界面,包括登录界面和主界面。
登录界面用于用户登录系统,主界面用于显示系统的各个功能模块。
3.功能实现:通过Java编程语言实现了宾馆信息管理系统的各个功能,包括宾馆基本信息的增、删、改、查功能,房间管理功能和客户信息管理功能等。
4.系统测试:对宾馆信息管理系统进行了功能测试和性能测试。
功能测试主要验证系统的各个功能是否正常运行,性能测试主要测试系统的响应速度和并发处理能力。
四、实验结果:经过测试,宾馆信息管理系统的各个功能均正常运行。
通过系统的增、删、改、查功能,可以实现对宾馆的基本信息进行管理;通过房间管理功能,可以查询和修改房间的状态;通过客户信息管理功能,可以实现客户的入住和退房操作。
五、实验总结:通过设计和实现宾馆信息管理系统,我掌握了数据库设计、程序编写和软件测试等相关知识和技能。
在实验过程中,我深刻体会到了系统设计和开发的重要性,合理的数据库设计和良好的用户界面可以提高系统的易用性和可维护性。
同时,系统测试也是一个不可或缺的环节,只有经过充分测试,确保系统的功能和性能达到要求,才能交付给用户使用。
通过本次实验,我不仅掌握了宾馆信息管理系统的设计和开发流程,而且增强了对数据库、编程和测试的理解。
这对我的后续学习和工作具有重要的意义。
宾馆管理系统数据库课程设计实验报告

数学及计算机科学学院课程名称:数据库原理实验项目名称:宾馆管理系统班级:14级计算机四班组长:朱贞琪组员:冯梦卓慧灵冯旭琴杨瑞平康妮牛明一、系统背景和研发资料整理1. 1系统背景在当今信息化越来越快的发展的环境下,各宾馆无论大小都争相采用网上宾馆管理方式。
相比而言,传统宾馆管理方式由于不方便、浪费资源等原因而落后了。
宾馆管理系统作为现时代的管理技术,广受人们欢迎。
宾馆管理系统由于其科学性、简便性、效率高、公平性和准确性从而提高管理效率。
本课程设计目的是探索学生选课的需求分析、概要设计、逻辑设计及规范化、数据库对象设计、数据统计这几个方面的内容。
为了更好地在以后的工作中能完成数据库建立和使用等操作。
使用MySQL数据库来设计数据库物理结构设计,包括数据库、数据表、索引、视图、触发器、存储过程、事务等,以达到数据库的操作和使用者的要求。
式的信息交互方式已经被人们广泛应用。
让计算机来管理顾客的信息是现在各个宾馆都在积极进行的工作之一,也是宾馆管理工作的重要内容之一。
数据库对于一个应用系统的意义是相当重要的,一个设计良好的数据库系统一方面,能够给开发者带来便捷,更轻松的进行系统设计及编码;另一方面,对于系统的后期维护也非常重要,一个良好的数据库系统能够保证系统的可扩充性,以及系统的移植性等问题。
1.2研发资料整理在研发学生选课系统的过程中,我选择了《数据库设计项目开发实例》《数据库设计》等资料,这些资料包含项目开发的需求分析,概念结构分析,逻辑结构分析,数据字典,数据库实施及维护,以及语言基础等等。
二、需求分析2.1 客房管理系统分析客房管理是学校宾馆管理中的一项重要任务,以往的手工操作已经不能适应现在办公的需要。
为了摆脱繁琐的劳动,提高工作效率,利用计算机进行信息处理成为必然。
开发功能完善及安全可靠的管理系统可以大大提高宾馆资源的利用率,及时,准确地获取需要的信息,充分发挥人员的工作潜力。
正是咨询业的迅速发展使得人们从过去的手工劳动中得以解脱。
数据库课程设计(宾馆管理系统)

数据库原理课程设计报告设计题目宾馆管理系统专业班级学号学生姓名指导教师起止日期*********系目录1.问题描述 (1)1.1背景 (1)1.2功能要求 (1)2.需求分析 (1)2.1数据流程图 (1)2.2数据字典 (5)3.概念结构设计 (6)3.1 E-R图 (6)3.2实体及联系的属性: (7)4.逻辑结构设计 (7)5. 触发器设计 (9)6. 存储过程设计 (9)7.应用程序实现 (12)8.结束语 (21)9.答辩与成绩考核 (22)1.问题描述1.1背景经调查了解后发现,目前较多的宾馆在客房管理上还处于人工阶段,效率低下且存在较多问题,为减少类似弊端开发此系统,以实现客房管理的电子化、科学化与现代化。
系统包括:旅客基本信息管理、客房基本信息管理、住宿基本信息管理、客房物品基本信息管理、工作人员基本信息管理五大功能模块。
可以实现对每个功能模块的查询和更新功能,其中查询功能主要是通过视图实现,而更新功能则是通过存储过程来实现。
在五大功能模块中,宾馆住宿基本信息和客房基本信息的管理是本系统开发的重点。
本系统的开发过程包括了需求分析阶段、概念设计阶段、逻辑设计阶段、数据库实施阶段、系统调试和测试阶段、参考文献及附录整理等阶段。
宾馆是现代社会服务行业体系中的重要组成部分,它在社会发展中有着不可替代的作用。
在当今经济和商务交往日益频繁的状况下,客房服务行业正面临客流量骤增的压力。
传统的宾店客房管理一直以来使用人工的方式管理文件档案,这种管理方式存在着许多缺点,如:效率低、保密性差;时间一长,将产生大量的文件和数据,这对于查找、更新和维护都带来了不少的困难;管理者往往要花大量的时间来处理烦琐的登记和结帐手续;不能及时提供空余客房资料等问题,将直接影响出租率。
据此现状,开发出本宾馆客房管理系统,通过本系统的应用不仅可以使宾馆客房管理科学化、正规化,而且对于提高员工工作效率,加速资金周转、降低各项成本及改善服务质量都有十分积极的作用。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
数据库课程设计报告-宾馆信息管理系统数据库课程设计报告 -------宾馆信息管理系统计算机科学与技术学院08级电子商务专业一、系统开发平台题目:酒店信息管理预订系统开发语言:Java Eclipse /netbeans后台数据库管理系统:SQL Server 2000操作系统:windows xp二、数据库规划2.1 任务陈述➢引言客房管理系统是典型的信息管理系统的一部份,而且是必不可少的一部份。
其开发主要包括后台数据库的建立和维护以及前端应用程序的开发两个方面。
对于前者要求建立起简洁且资料一致性和完整性强、资料安全性好的数据库。
而对于后者则要求应用程序功能完备,易使用等特点。
酒店客房管理系统的内容对于经营的决策者和管理者来说都至关重要,所以客房管理系统、信息管理系统应该能够为用户提供充足的信息和快捷的查询手段。
但一直以来人们使用传统人工的方式管理文件档案,这种管理方式存在着许多弊端,如:效率低、保密性差,容易出现差错等,且对于查询空房间及已定房间等极为不方便。
在当今时代,这些完全可以改用计算机来代替人的手工操作。
作为计算机及网络应用的一部分,使用计算机对客房信息进行管理,具有手工管理所无法比拟的优点。
例如:检索迅速、查找方便、可靠性高、存储量大、保密性好、寿命长、成本低等。
这些优点能够极大地提高客房经营管理的效率,也是企业的科学化、正规化管理,与世界接轨的重要条件。
且办事效率也是决定收入的一个关键因素。
因此,我选择的酒店客房管理系统设计,力求开发出一套界面友好,功能强大,使用简单的适用于各大、中、小规模的酒店客房的管理系统。
同时也是一款完全适合宾馆或旅馆酒店客房管理傻瓜式日常业务管理的软件。
酒店系统由前台和后台管理两个部分组成。
前台作为与前台服务员直接交互的可视化界面,由于使用方便,能将系统的各个功能提供给他们,以帮助服务员进行客房管理。
前台在考虑功能实现的同时,也考虑了操作的简洁和方便性,目的是让大多数客户能够轻松地享受电子商务给他们带来的便利。
为了确保客户和酒店的信息具有更好的安全性,前台管理和后台管理是分离的。
前台的各管理模块只有部分功能和权限,我为此设计了两个角色:一是酒店管理员,二是前台服务员。
其中:酒店管理员享有最高权限,可以使用酒店客房管理系统所提供的所有功能,包括员工信息修改、客房类型维护、客房信息维护、客户信息查询。
前台服务员的主要职能是负责订房,入住和退房,以及查询和修改订单,查询房间信息和查询预订及入住的客户信息。
所有该角色只可以使用部分功能,后台管理主要由数据库系统作为支持,后台管理的维护工作主要由系统管理员进行。
➢数据库管理系统由于酒店管理系统是一个典型的数据库应用系统,因而选择一个良好的DBMS是系统实现的另一个重要环节。
DBMS访问数据库。
一般来说现代的DBMS具备以下几个功能:(1)事务的恢复功能:为尽可能减少由于故障而引起的数据库数据失效的损失,现代的DBMS 通常具备恢复功能。
(2)完整性约束检查:由于数据库中的数据是持久和共享的,其正确性十分重要,为保证数据的正确性,DBMS提供对数据库数据的语法和语义的检查,数据在语义上的约束称为完整性约束。
(3)访问控制:并不是任何用户可以不加限制的访问任何数据库中的数据,DBMS应有控制用户访问权限的功能,即所谓的访问控制功能,访问控制不但可以限制用户的访问范围,而且可以限制用户可进行的操作。
(4)数据目录管理:数据库中保留的是持久和共享的数据,对数据的定义应不同于一般的程序设计语言,应独立于应用程序,长期保留在数据库中,这就构成了数据目录,数据目录的管理是DBMS的基本功能。
2.2 任务目标➢设计目标(1)操作简单方便、界面简洁美观,方便中小型酒店人员使用。
(2)前台服务员功能:住宿管理:客房预订(能实现散客和团体客户预订,团体预订可预订多间不同类型的房间,并在这些房间中选择一个作为主房间号)客人入住(能实现散客和团体客户入住,团体入住可选择多间不同类型的房间,并在这些房间中选择一个作为主房间号)客户信息录入(在订单生成页面将录入客户信息,团体客户只记录一位主客户信息,而不需所有客户依次登记)入住押金管理(押金设为住宿总费用的百分之五十,在开入住订单时系统自动计算并显示)信息管理:预订和入住订单查询(可按订单号、客户身份证号、入住类型查询)团体订单细则(对团体订单中每一个房间信息显示)修改预订订单和入住订单(可修改主客的基本信息及订单信息)取消预订订单(直接删除预订订单,恢复房间的可用状态)将预订订单直接转为入住(省去了再次生成入住订单的程序)房间查询(可按照房间号、房间类型、房间状态查询)客户查询(可按照客户姓名、客户身份证号、入住类型查询)入住客户中途换房(只能换同种类型房间,消费金额不变)入住客户正常退房(根据入住时间计算消费金额,最后客户应缴费用为总费用与已交押金之差)(3)管理员功能:除了前台接待的功能之外,还包括房间信息设定及修改(包括客房类型,客房分机号,楼层,备注)个人信息修改(包括个人密码,联系方式,住址)增加客房类型(包括类型号,单价,床位数,房间设施,面积等)增加客房信息(包括房间号,房间类型,房间分机,楼层,备注)(4)酒店介绍等信息:介绍酒店的地址,房间价格标准,联系电话等信息三、系统定义3.1 系统边界3.2 用户视图➢ 前台服务员散客客房预订与入住前的房间查询 散客预订生成订单,录入客户基本信息 散客入住生成订单,录入客户基本信息团体客房预订与入住前房间查询,设置主房间号团体预订生成订单,录入主客户基本信息 团体入住生成订单,录入主客户基本信息 预订订单信息查询 预订订单修改团体预订订单所有房间信息细则 取消预订订单 入住订单信息查询 入住订单修改团体入住订单所有房间信息细则客房信息查询酒店信息住宿管客房管后台管散客客房预订 散客客房入住预订订单查询 入住订单查询个人信息维护 增加客退换房 已住订单换房客户信息查询入住换房管理入住正常退房及消费结账管理➢后台管理员后台管理员登陆管理员个人功能主页个人信息修改增加客房类型增加客房信息修改已有客房信息四、需求分析4.1 用户需求分析4.1.1 数据需求➢前台服务员用户视图预订信息:预订订单号(唯一),客户身份证号,客户姓名,主客房间号,预订房间数,入住类型(散客/团体),预订时间,入住时间,入住天数,主客电话。
预订登记:预订登记号(唯一),所属预订订单号,房间号,房间类型号,房间类型,预订时间,入住时间,入住天数,房间单价。
入住信息:入住订单号(唯一),客户身份证号,客户姓名,主客房间号,预订房间数,入住类型(散客/团体),入住时间,入住天数,主客电话,房间总费用,需收押金。
入住登记:入住登记号(唯一),所属入住订单号,房间号,房间类型号,房间类型,预订时间,入住时间,入住天数,房间单价。
客户信息:客户身份证号(唯一),客户姓名,客户电话,性别,备注客房信息:房间号,房间类型号,房间类型(标准间/高级套房/普通单间/总统套房),房间状态(可用/预订/入住),楼层,分机号,备注换房信息:房间号,房间类型,客户姓名,客户身份证号,订单号退房信息:订单号,客户姓名,客户身份证号,入住时间,入住天数,房间单价,已交押金,房间总费用,还需缴纳费用➢后台管理员用户视图管理员登陆:管理员账号,管理员密码管理员个人信息维护:管理员姓名,管理员账号,管理员密码,联系电话,住址,职务增加房间类型:房间类型号,房间类型名称,房间单价,床位数,面积,房间设施增加客房:房间号,房间类型,房间状态,楼层,分机,备注4.1.2 事务需求➢前台服务员视图:数据查询:现有各类房间的详细信息以供预订或入住列出已有所有预订订单列出已有所有入住订单列出所有客房信息(可用/已住/预订)列出所有客户信息(预订/入住)列出某客户的订单情况列出某团体的所有登记房间情况列出需要换房的房间信息以及所有同种类型当前可用房间信息列出需要退房的房间信息,已交金额及需交金额显示酒店详细信息数据录入:录入客户需要的房间信息(选择房间类型及房间数目)录入客户的基本信息(姓名,身份证号,电话等)录入订单信息(时间,入住天数)录入订单修改信息(修改预订及入住订单,及取消订单)录入换房信息录入退房信息数据输出:输出酒店现有有所类型房间的数目自动输出预订订单及入住订单的订单号和登记号(每一个订单有一个订单号,一个订单中的每个房间有一个登记号,一个登记号对应一个订单号,一个订单号对应一个或多个登记号。
订单号和登记号按系统时间自动生成)自动输出退房信息,退房所需交的金额➢后台管理员视图数据录入:录入管理员账号,密码录入个人修改信息(密码,电话,住址)录入新增加房间类型(类型号,类型名称,单价等)录入新增加房间信息(房间号,房间类型,分机,楼层)录入已有房间修改信息(房间号,房间类型等)数据查询:列出现有所有房间信息列出个人所有信息列出修改后的房间信息数据输出:输出增加的房间类型输出增加的房间信息4.2 系统需求说明4.2.1 软件环境软件环境需要支持Window操作系统,及SQL Server 2000商业数据库4.2.2 硬件环境Inter(R)Core(TM)2 Duo CPU T5670 1.80GHz 1.79 GHz, 504MB内存4.2.3 初始数据库大小客房信息40条员工信息4条客户信息15条预订订单信息8条入住订单信息7条预订登记信息15条入住登记信息15条4.2.4 数据库增长速度住宿信息每天增长大约50条预订信息每天增长大约50条退宿信息每天增长大约30条换房信息每天增长大约10条其他信息增长速度不定4.2.5记录查找的类型和平均数量查询客房信息大约每天50次查询住宿信息大约每天50次查询客户信息大约每天50次查询退宿信息大约每天50次4.2.6 安全性管理员和服务员有不同的权限每个管理员登录系统是需要身份验证(前台服务员不需要)订单酒店 客房房间预订登有 属客户预订预入管管理所属登订入住登入住订登登所属五、数据库逻辑设计5.1 ER 图5.2 数据字典5.2.1实体和联系属性客房信息(房间号,房间类型号,房间类型,房间状态,楼层,房间分机,备注)房间类型(房间类型号,类型名称,房间单价,面积,床位数,房间设施)客户信息(身份证号,客户姓名,联系电话,性别,备注)预订订单(预订订单号,主客姓名,主客身份证号,主客房间号,入住类型,房间数目,预订时间,入住时间,入住天数,客户电话)预订登记表(预订登记号,所属预订订单号,房间号,房间类型号,房间类型,预订时间,入住时间,入住天数,入住类型,房间单价)入住订单(入住订单号,主客姓名,主客身份证号,主客房间号,入住类型,房间数目,入住时间,入住天数,客户电话,房间总费用,需交押金)入住登记表(入住登记号,所属入住订单号,房间号,房间类型号,房间类型,入住时间,入住天数,入住类型,房间单价)团体入住信息(团体入住订单号,主客姓名,主客身份证号,客户人数,主客房间号,入住时间,入住天数,主客电话,房间总费用,需收押金)管理员(管理员账号,密码,管理员姓名,职位,联系电话,住址)5.2.2属性描述实体属性类型及大小空客户信息身份证号(key)char(10) 否客户姓名varchar(50) 否联系电话varchar(50) 否性别varchar(50) 否备注varchar(50)客房信息房间号(key)char(10) 否房间类型号char(10) 否房间类型verchar(50) 否房间状态verchar(50) 否房间分机char(10) 否楼层char(10) 否备注varchar(10)管理员管理员账号(key)char(10) 否密码char(10) 否职位varchar(50) 否联系方式char(10) 否住址varchar(50)预订订单预订订单号(key) char(10) 否主客姓名varchar(50) 否主客身份证号char(10) 否入住类型varchar(50) 否预订房间数目char(10) 否主客房间号char(10) 否预订时间Datetime 否入住时间Datetime 否入住天数Char(10) 否主客电话Char(10) 否预订登记表预订登记号(key)char(10) 否所属预订订单号char(10) 否房间号char(10) 否房间类型号char(10) 否房间类型varchar(50)否预订时间datetime(8) 否入住时间datetime(8) 否入住天数char(10) 否入住类型varchar(50)否房间单价char(10) 否入住订单入住订单号(key) char(10) 否主客姓名varchar(50) 否主客身份证号char(10) 否入住类型varchar(50) 否入住房间数目char(10) 否主客房间号char(10) 否入住时间Datetime 否入住天数Char(10) 否主客电话Char(10) 否房间总费用Char(10) 否需交押金Char(10) 否入住登记表入住登记号(key)char(10) 否所属入住订单号char(10) 否房间号char(10) 否房间类型号char(10) 否房间类型varchar(50)否入住时间datetime(8) 否入住天数char(10) 否入住类型varchar(50)否房间单价char(10) 否房间类型房间类型号(key)char(10) 否类型名称varchar(50)否床位数char(10) 否单价char(10) 否房间设施varchar(50)否面积char(10) 否5.3关系表六、数据库物理设计6.1 索引使用查询分析器运行:USE 酒店管理系统DBCC SHOWCONTIG WITH TABLERESULTS, ALL_INDEXES可以得到“酒店管理系统”数据库中全部索引的相关信息,其中用户所建表的部分信息如下:ObjectName ID IndexNameAverageFreeBytesLogicalFragementation入住订单18099105PK_团体入住信息6384.0 0.0入住登记表210099789PK_团体入住登记表5240.0 0.0客户信息837578022PK_客户信息4730.0 100.0房间类型933578364PK_房间类型7422.0 0.0客房信息1669580986PK_客房信息3876.0 100.0管理员1909581841 PK_高级管理7617.0 0.0预订订单2021582240PK_团体预订信息6278.0 0.0预订登记表2085582468PK_团体预订登记表4280.0 100.0以上都是主键索引。