1、1酒店客房管理系统的设计简介本综合课程设计课题为“酒店客房管理系统” 。随着社会经济的发展,人们的生活水平得到了极大的提高。作为服务业之一的酒店业也在急速发展。酒店管理者需要及时得到近点的运营情况,以便快速的为消费者提供服务。在这种背景下,人工管理远远不能提供高效的、便捷的处理经营中需要的大量的信息,进而影响的酒店的营业效率。传统的管理模式已经不能满足如今的社会需求。因此便需要一种能够提供高效服务的方式。酒店客房管理系统便是一个能够提供这种服务的管理系统。利用酒店管理系统中合理的数据库存储数据及时了解各个环节的数据信息,通过有效的程序结构来有效的支持各种数据操作,以提高管理效率实现酒店服务的系
2、统化、规范化、自动化。通过该项目的开发与使用,酒店可以改善酒店额管理与运行效率,提高服务质量,节省开支,提高劳动效率。2目录第 1 章 绪论31.1 项目背景31.1 总体目标3第 2 章 编程语言及工具42.1 SQL 与MySQL42.2 Java 与Eclipse6第 3 章 系统设计733.1 需求分析73.2 数据库设计73.3 界面设计83.4 算法设计12第 4 章 系统测试14第 5 章 开发设计总结155.1 心得体会155.2 结束4语16参考书籍16源代码以及 jdbc 包均与上传至百度网盘 http:/ 1 章 绪论1.1 项目背景近年来,酒店行业发展迅速,市场竞争日益
3、激烈,为了提高酒店竞争力,酒店管理方式的改进势在必行。传统的人工管理模式已经远远不能有效、便捷地处理酒店经营中产生的大量数据,从而使酒店经营中效率低下。而且人工管理中工人工资产生了巨大的经营成本,使酒店经营效率低下。为了提升酒店的经营效率,降低成本,必须采用更加合理有效的管理模式。只有把管理做到细微,才能够为顾客提供高标准、高质量的服务,从而进一步提升企业竞争力。传统的管理方法已经不能满足现代化的信息社会的需求,因此采用电脑管理已经成为推动酒店发展的重要途径,本课题研究的酒店管理系统就是一个致力于5提高酒店经营效率,降低成本,能够更加快速、便捷地为顾客提供服务的信息管理系统。1.2 总体目标建
4、立一套功能完善、设计合理、结构科学的信息管理系统,能满足业务管理人员的需要,提高酒店经营管理过程中的数字化水平,大幅度提高工作效率。从而提高实施管理的准确性、科学性,使负责管理的工作人员能够从大量繁杂的手工劳动中解脱出来。提高服务质量,节约开支,提高劳动生产率,从而赢得高信誉、强实力、好效益。为了达到以上效果,需要实现的功能如下: 查询房间信息(房间号、房间类型、价格、是否空房) 快速实现顾客入住,等级客人信息、入住房间 查询入住信息,每个客人对应的房间信息 快速实现退房服务,计算顾客应付金额第 2 章 编程工具及语言本系统采用 C/S 模式,一共分为两部分。第一部分为服务器部分,采用语言为
5、SQL 使用的编程工具是 MySQL;第二部分为客户端部分,采用的语言是 Java,编程工具为 Eclipse。2.1SQL 与 MySQL6SQL 语言集数据查询(data query) 、数据操纵(data manipulation) 、数据定义(data definition)和数据控制(data control)功能于一体,充分体现了关系数据语言的特点和优点。其主要特点包括:1.综合统一:SQL 语言集数据定义语言 DDL、数据操纵语言 DML、数据控制语言 DCL 的功能于一体,语言风格统一,可以独立完成数据库生命周期中的全部活动。2.高度非过程化:非关系数据模型的数据操纵语言是面向
6、过程的语言,用其完成某项请求,必须指定存取路径。而用 SQL 语言进行数据操作,用户只需提出“做什么” ,而不必指明“ 怎么做” 。这不但大大减轻了用户的负担,而且有利于提高数据独立性。3.面向集合的操作方式SQL 语言采用集合操作方式,不仅查找的结果是元组的集合,而且一次插入、删除、更新操作的对象也是元组的集合。不用像非关系数据模型那样,任何一个操作对象都是一条记录,每一个操作都需要如何对每一条记录进行操作。4.同一种语法结构提高两种使用方式SQL 语言既是自含式语言,又是嵌入式语言。而在这两种不同的使用方式下,SQL 语言的语法结构基本上是一致的。这种统一的语法结构提供两种使用方式的做法,
7、为用户提供了极大的灵活性7和方便些。MySQL 是目前关系型数据库管理系统之一,MySQL 数据库因其体积小、速度快、总体拥有成本低受到中小企业的热捧。MySQL 是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。MySQL 所使用的语言是用于访问数据库的最常用标准化语言 SQL。它为 C、C+、Java 等编程语言提供了应用程序编程接口(API ) ,提供 TCP/IP、ODBC 和 JDBC 等多种数据库连接途径,提供多语言支持,常见的编码如中文的 GB 2312、BIG5,日文的Shift_JIS 等都可以用作数
8、据表名和数据列名。基于以上特点,在本系统开发中选择 SQL 与 MySQL 作为数据库开发的语言和工具。2.2 Java 与 EclipseJava 语言是一种面向对象的语言,从 C+发展而来,有选择的继承了 C+语言的语法规则和面向对象的基本机制,放弃了 C+语言模糊、过于复杂、安全性差、不适合网络应用的诸多特性。它通过提供最基本的方法来完成指定的任务,只需理解一些基本的概念,就可以用它编写出适合于各种情况的应用程序。Java 具有平台无性,一个应用程序可以运行于不同的操作系统平台。Java 具有 JDBC(Java Database Connectivity,Java 数据库连接)技术,定
9、义了 Java 应用程序与关系型数据库连接的规范,可以很方便的实现与数据库的通信。8Java 图形用户界面的组件和事件由 java.awt 和 javax.swing包共同提供。Java.awt 称为抽象窗口工具,主要包括组件、事件处理模型、图形和图像工具、布局管理器等,其中的组件统称为 AWT组件。Swing 组件扩展了 AWT 组件的功能。使用 JDK 提供的 AWT 组件和 Swing 组件可以很简单的实现图形界面和人机交互。Eclipse 是一个开放的、基于 Java 的可扩展的通用开发平台。Eclipse 的核心非常小,其他功能均已插件形式附加到核心上。Eclipse 可以与 API
10、、JDT、PDE 等插件无缝结合,实现强大的功能。第 3 章 系统设计3.1 需求分析本系统旨在减轻酒店工作人员负担,为酒店营业提供服务。从客房营销开始,从客房的信息查询,到客人入住,到查询住宿信息,退房结账,整个过程都应该能够体现以顾客为本,为顾客提供高效的服务。整个过程可以分为四个阶段,查询房间信息、登记客人信息入住、查询住宿信息、退房结账。则本系统功能就以这四项为主线来依次实现。3.2 数据库设计根据需求分析,按照第三范式设计可画出如下 E-R 图9将 E-R 图转化为关系模型可得:顾客 customer(Cno,Cid,Cname,Cage,Csex);房间等级 RLevel(RLno
11、,RLname,RPrice);房间 room(Rno,RLno,Usable);住宿信息 CR(CRno,Rno,Cno,Btime);通过上面分析,可知我们需要四个表格Customer 客人信息表字段名 中文含义 数据类型 说明Cno 客人编号 Char(4) PKCid 客人身份证号 Char(18) UniqueCname 客人姓名 Char( 20)Csex 客人性别 Char( 2) check (Csex in(男,女)10Cage 客人年龄 IntRoom 房间表字段名 中文含义 数据类型 说明Rno 房间号 Char(4) PKRLno 房间等级号 Char(4) FK Us
12、able 是否空房 Int Check(in(0,1)RLevel 房间等级表字段名 中文含义 数据类型 说明RLno 等级编号 Char(4) PKRLname 等级名称 Char(20)Rprice 价格 IntCR 住宿表字段名 中文含义 数据类型 说明CRno 住宿号 Char(4) PKRno 房间号 Char(4) FKCno 客人编号 Char(4) Fk Btime 入住时间 Datetime创建两个视图,分别用于展示住宿详情和房间详情。房间详情11(房间号,房间类型,房间价格,是否空房) ,住宿详情(住宿号,客人号,客人身份证号,客人姓名,客人性别,客人年龄,房间号,房间类型
13、,房间价格,入住时间) 。3.3 界面设计1.登陆界面本界面是用于用户打开系统是验证身份。首先需要提供两个文本框,分别输入用户名和密码;其次需要一个“确定”按钮,验证输入的用户名和密码,和一个“取消”按钮,用于退出系统。当身份验证不通过是给出提示对话框(“用户名或密码错误”)。2.主界面本界面为身份验证通过后打开的界面,为本系统操作的主要界面,为了实现需要的四个功能,则需要四个按钮,分别是“客房情况”、“住宿情况”、“入住”和“退房”。123.客房情况界面本界面为客房情况的查询结果,需要一个 JTable 来展示查询结果,一个“返回”按钮,返回主界面。4.入住界面需要 6 个文本条分别输入“客
14、人号” 、 “身份证号” 、 “姓名” 、 “性别” 、 “年龄”和“房间号” ;一个“确定”按钮,将文本条中信息转存入数据库;一个“取消”按钮返回主界面。135.查询住宿情况界面本界面为住宿情况查询结果,需要有一个 JTable 展示住宿情况查询结果,还要有一个“返回”按钮返回主界面。6.退房界面退房功能要求输入要退房的顾客身份证号,则此界面需要一个文本框,另外需要一个“确定”按钮执行退房操作14和一个“取消”按钮返回主界面。7.退房结果本界面要输出顾客应付金额,以及退房结果。需要一个 JTable 显示顾客应付金额,一个“确定”按钮返回主界面。3.4 算法设计1. 登陆功能将输入的用户名和
15、密码传输到 MySQL 数据库进行验证,验证成功则进入主界面,验证失败则弹出对话框提醒“用户名或密码错误” 。2.查询房间情况15直接从数据库中房间详情视图查询数据。其中如果Usable 字段对应属性为 0, “是否空房”为否;如果Usable 字段对应属性为 1, “是否空房”为是。3.入住功能将客人信息(客人编号,客人身份证号,客人姓名,客人性别,客人年龄)插入客人表格。更新房间表格,将房间号等于输入房间号的元组中的Usable 字段设置为 0;将住宿信息(客人编号,房间编号, )插入住宿表格,其中主键住宿号自动增加,入住时间为当前日期。4.查询住宿情况直接从数据库中住宿详情视图查询数据。
16、5.退房功能从客人信息表格中得到对应“客人身份证号”的“客人编号” ,从住宿情况表格中得到对应“客人编号”的“房间编号” ,更新房间表格,将“房间编号”等于对应“房间编号”房间的 Usable 设置为 1.将住宿情况表格中“房间编号”等于得到的“房间编号”的元组删除。将客人信息表中“客人编号”等于输入“客人编号”的元组删除。第 4 章 系统测试16测试的目的是要发现软件中的错误,并加以改正。测试的方法主要分为单元测试和集成测试。单元测试:对模块中的几个小单元进行单独测试,若均完成预计功能,便可进行下一步的集成测试。集 成 测 试 : 集 成 测 试 是 组 装 软 件 的 系 统 技 术 ,
17、主 要 有 两 种 方 法 。 一 种 是 先分别测试每个模块,再把所有模块按设计要求放在一起结合成所要的程序,成为非渐增式测试方法;另一种是把下一个要测试的模块同已经测试好的模块结合起来进行测试,测试完以后再把下一个应该测试的模块结合近来测试,称为渐增式测试。我们所用到的是第一种方法,将所有模块结合到一起进行测试。测试是一项复杂的、具有创造性的工作,也是在软件开发中容易被忽视的一个阶段。在实际的测试中,可以将测试方法和过程反复进行,各种方法需要灵活地进行组合使用,力求发现所有的错误,并进行改正。只有这样才能为生产出高质量的软件打下基础。第 5 章 开发设计总结5.1 开发心得:至此,整个酒店
18、客房管理系统开发完毕。在开发过程中有以下心得:第一,前期的需求分析和软件设计阶段极为重要,不要急于开始软件开发写代码的过程,只有前期做好需求分析和软件设计的工作,在后期开发过程中按照设计好的内容一步一步实现,才能保证软件开发的成功率。否则在软件开发的过程中则需要大量的精力17和时间进行修改,而且修改还会带来更多心得问题,浪费更多的人力物力。第二,学习了根据需求设计数据库和图形和界面,以及如何将数据库与用户界面相链接。这是 MIS 系统开发中的核心技术。而各种 MIS 系统的开发是想通的,通过在酒店客房管理系统的开发过程中得到的理论和实践经验可以为其他的 MIS 系统开发提供很大帮助。第三,在开
19、发过程中注意多写用户文档和注释。文档是软件开发阶段成果的标志。注释可以帮助你在之后的对代码的分析和修改过程中起到极大的帮助,否则都有可能看不到之前自己写过的代码,而且如果与其他人共同开发,没有注释则会导致交流困难。5.2 结束语经过一个多星期的努力,一个完整的酒店客房管理系统就创建完毕了,在此详细介绍了从需求分析到数据库设计,图形界面设计,算法设计,代码实现,直到软件测试等一个完整的过程,基本实现了预期的功能。在此过程中也存在着一些问题,例如界面设计简陋等多方面,仍需要改善。在整个开发过程中也遇到了一些难以解决的问题,例如在 Eclipse 中如何链接数据库,如何修改数据库等等问题。在吴立军老师的帮助下最终解决了这些问题。我在此次综合课程设计中积累了一些宝贵经验,软件水平有了很大提高。总之,理论+实践=知识。在这次设计中我成功的将之前课堂上学习的知识与开发过程中得到的实践经验结合起来,亲身体会到只18有将理论与实践紧密结合才能使学习效率大大提高。参考书籍1.数据库系统及应用(第 2 版) 电子工业出版社 2012 年 4 月第 2 版2.Java 程序设计实用教程(第 3 版) 电子工业出版社 2012 年 2 月低 3 版