springboot酒店客房管理系统设计与实现(代码+数据库+LW)
摘 要
酒店客房管理系统的目的是让使用者可以更方便的将人、设备和场景更立体的连接在一起。能让用户以更科幻的方式使用产品,体验高科技时代带给人们的方便,同时也能让用户体会到与以往常规产品不同的体验风格。
与安卓,iOS相比较起来,酒店客房管理系统在流畅性,续航能力,等方方面面都有着很大的优势。这就意味着酒店客房管理系统的设计可以比其他系统更为出色的能力,可以更高效的完成最新的酒店客房、客房预定、客房入住、退房登记等功能。
此系统设计主要采用的是JAVA语言来进行开发,采用Spring Boot框架技术,框架分为三层,分别是控制层Controller,业务处理层Service,持久层dao,能够采用多层次管理开发,对于各个模块设计制作有一定的安全性;数据库方面主要采用的是MySQL来进行开发,其特点是稳定性好,数据库存储容量大,处理能力快等优势;服务器采用的是Tomcat服务,能够提供稳固的运行平台,确保系统稳定运行。通过酒店客房管理系统来提升本课题的各项功能的工作效率,提供了一个多样功能,具有良好实用性的酒店客房管理系统。
关键词:酒店客房管理系统;Spring Boot框架;JAVA语言
目 录
摘 要 I
Abstract II
1 绪 论
1.1研究意义
1.2系统设计目的
1.3系统设计思想
2系统需求分析 3
2.1系统性能需求 3
2.2系统用例图
2.3可行性分析
2.3.1经济可行性
2.3.2技术可行性
2.3.3社会可行性
2.4系统开发技术
2.4.1 springboot框架
2.4.2 B/S架构
2.4.3 MySQL介绍
2.4.4 Java介绍
2.5系统流程分析 10
3系统设计
3.1系统功能结构
3.1.1系统结构图
3.2数据库设计
3.2.1 数据库概念设计
3.2.2数据逻辑结构
4系统详细设计
4.1登录模块设计
4.2管理员功能模块
4.3 员工功能模块
4.4 清洁工功能模块
4.5 客户功能模块
4.6 前台功能模块
5 软件测试
5.1软件测试原则
5.2测试用例 30
结 论
参考文献
致 谢
1 绪 论
近些年来,随着电子科学技术的高速发展,计算机相关行业的发展创新。衍生出了各种各样方便快捷的电子设备。如手机,电脑等。这些电子设备功能强大,方便所有类型的人们使用。但这些年来,人们对手机,电脑等电子高科技产物的依赖和需求也越来越大。现在的人们已经不再满足于它们各式各样的基础功能,例如与他人通讯,上网了解信息等。人们现在更希望的是随着科技的发展,手机、电脑等高科技产品可以给自己带来更多方便快捷、简单实用的功能。同时也希望自己在使用的时候可以更轻松的掌握使用这些设备的技巧。同时,伴随着这些电子设备的出现,操作系统就显的尤为重要,电子设备各式各样功能的顺利运行都要依靠它的稳定运行。操作系统可以管理、控制计算机的硬件资源和软件资源,也是计算机最为基本的系统软件。人们所有能涉及到和使用到的软件运行几乎都离不开它。它就像人类的大脑一样,控制着计算机的各种设备。但同样,操作系统在发展时自身也会出现很多问题,同样的系统不能应用在所有的硬件设备上。这个问题对于大部分的电子科技受益者来说很陌生,处理起来很有困难。会让使用者不能在第一时间使用,因此会造成很多负面的影响。
什么是酒店客房管理系统?酒店客房管理系统区别于人们司空见惯的安卓系统和iOS系统,酒店客房管理系统希望只用一整套系统就解决使用的硬件设备需要有不同的系统的繁琐问题。它的出现不仅让使用者在使用时更加方便,还可以让使用者在使用选项上有了更多选择的余地。酒店客房管理系统十分流畅,可以让使用者在使用时几乎没有任何的延迟和卡顿,可以给使用者带来十分轻松的体验。并且可以在几乎我们能看到的所有电子设备上使用,大幅度的增加了酒店客房管理系统的使用范围。同时,酒店客房管理系统可以同步全部的连接对象,对于使用者来说这样的系统更加方便。它可以很精准的将使用者所需的各方面的酒店需求通过该系统提供给使用者,并且它的使用普遍性可以让各个年龄段的使用者都能有一个良好的使用体验。
1.1研究意义
伴随着科技的进步,时代的发展,越来越多的电子设备也随之出现在人们的眼前,在电子设备,软件技术成熟之前,人们可以选择使用电子设备,通过酒店软件的帮助,找到最适合自己,最符合自己的管理方式。而酒店客房的普及也伴随着很多问题,有的酒店软件不能适应用户使用的电子设备的系统,这会让部分使用者对这款软件彻底否认,会导致该系统失去预想的市场竞争力,面临淘汰。使用者更希望自己使用的酒店客房管理系统可以在完成最基本的功能需求的基础上变的更加稳定,流畅,并且没有任何因兼容性而引发的复杂问题。
而酒店客房管理系统的出现也渐渐让这种类似的问题有了一个相对明确的解决方案,酒店客房管理系统可以使软件的运行速度变的更快,并且可以同步全部的连接对象,可以确保项目的正确运行,同时,在如此信息化的时代里,使用者对软件的各项要求也越来越多,在如此广阔的信息量之下,使用者更希望自己使用的系统可以畅通无阻的浏览每个网页上的信息,可以全方位的了解酒店客房、客房预定、客房入住等的特点,根据自己的需求,选择最适合自己的方案。并且让整个电子信息时代都注入了新鲜的血液,且能更好的流向各个领域,各个行业,为电子信息时代继续发光发热。
系统用例图
本系统采用自上往下的方法开发,基本定位如下功能:
本课题要求实现一套酒店客房管理系统,系统主要包括管理员模块和客户、清洁工、员工模块的功能模块;
(1)管理员用例图如下所示:

(2)客户用例图如下所示:

(3)清洁工用例图如下所示:

(4)员工用例图如下所示:

系统结构图
系统结构图可以把杂乱无章的模块按照设计者的思维方式进行调整排序,可以让设计者在之后的添加,修改程序内容的过程中有一个很明显的思维方向。同时结构图还可以让设计者以外的其他人更直观的看出整个系统的设计理论和设计过程。让系统的设计变的更直观。该系统的功能架构图如图3-1所示:

数据逻辑结构
在综合了以上对系统的设计,和对数据库的分析,同时结合了以往对数据库的使用经验后,构建了以下几张表,以下为每张表的内容:
表3-1:客房类型
| 字段名称 | 类型 | 长度 | 字段说明 | 主键 | 默认值 | 
| id | bigint | 主键 | 主键 | ||
| addtime | timestamp | 创建时间 | CURRENT_TIMESTAMP | ||
| kefangleixing | varchar | 200 | 客房类型 | 
表3-2:酒店客房
| 字段名称 | 类型 | 长度 | 字段说明 | 主键 | 默认值 | 
| id | bigint | 主键 | 主键 | ||
| addtime | timestamp | 创建时间 | CURRENT_TIMESTAMP | ||
| kefangmingcheng | varchar | 200 | 客房名称 | ||
| kefanglouceng | varchar | 200 | 客房楼层 | ||
| kefangleixing | varchar | 200 | 客房类型 | ||
| kefangtupian | longtext | 4294967295 | 客房图片 | ||
| kefangsheshi | varchar | 200 | 客房设施 | ||
| kefangjiage | int | 客房价格 | |||
| kefangzhuangtai | varchar | 200 | 客房状态 | ||
| jiudianmingcheng | varchar | 200 | 酒店名称 | ||
| jiudiandizhi | varchar | 200 | 酒店地址 | ||
| lianxidianhua | varchar | 200 | 联系电话 | ||
| kefangjieshao | longtext | 4294967295 | 客房介绍 | ||
| yuangonggonghao | varchar | 200 | 员工工号 | ||
| yuangongxingming | varchar | 200 | 员工姓名 | 
表3-3:用户表
| 字段名称 | 类型 | 长度 | 字段说明 | 主键 | 默认值 | 
| id | bigint | 主键 | 主键 | ||
| username | varchar | 100 | 用户名 | ||
| password | varchar | 100 | 密码 | ||
| role | varchar | 100 | 角色 | 管理员 | |
| addtime | timestamp | 新增时间 | CURRENT_TIMESTAMP | 
表3-4:酒店客房评论表
| 字段名称 | 类型 | 长度 | 字段说明 | 主键 | 默认值 | 
| id | bigint | 主键 | 主键 | ||
| addtime | timestamp | 创建时间 | CURRENT_TIMESTAMP | ||
| refid | bigint | 关联表id | |||
| userid | bigint | 用户id | |||
| avatarurl | longtext | 4294967295 | 头像 | ||
| nickname | varchar | 200 | 用户名 | ||
| content | longtext | 4294967295 | 评论内容 | ||
| reply | longtext | 4294967295 | 回复内容 | 
表3-5:退房登记
| 字段名称 | 类型 | 长度 | 字段说明 | 主键 | 默认值 | 
| id | bigint | 主键 | 主键 | ||
| addtime | timestamp | 创建时间 | CURRENT_TIMESTAMP | ||
| kefangmingcheng | varchar | 200 | 客房名称 | ||
| kefangleixing | varchar | 200 | 客房类型 | ||
| tuifangshijian | datetime | 退房时间 | |||
| kehuzhanghao | varchar | 200 | 客户账号 | ||
| kehuxingming | varchar | 200 | 客户姓名 | ||
| shouji | varchar | 200 | 手机 | ||
| dengjishijian | datetime | 登记时间 | |||
| beizhu | longtext | 4294967295 | 备注 | ||
| yuangonggonghao | varchar | 200 | 员工工号 | ||
| yuangongxingming | varchar | 200 | 员工姓名 | 
表3-6:配置文件
| 字段名称 | 类型 | 长度 | 字段说明 | 主键 | 默认值 | 
| id | bigint | 主键 | 主键 | ||
| name | varchar | 100 | 配置参数名称 | ||
| value | varchar | 100 | 配置参数值 | 
表3-7:token表
| 字段名称 | 类型 | 长度 | 字段说明 | 主键 | 默认值 | 
| id | bigint | 主键 | 主键 | ||
| userid | bigint | 用户id | |||
| username | varchar | 100 | 用户名 | ||
| tablename | varchar | 100 | 表名 | ||
| role | varchar | 100 | 角色 | ||
| token | varchar | 200 | 密码 | ||
| addtime | timestamp | 新增时间 | CURRENT_TIMESTAMP | ||
| expiratedtime | timestamp | 过期时间 | CURRENT_TIMESTAMP | 
表3-8:收藏表
| 字段名称 | 类型 | 长度 | 字段说明 | 主键 | 默认值 | 
| id | bigint | 主键 | 主键 | ||
| addtime | timestamp | 创建时间 | CURRENT_TIMESTAMP | ||
| userid | bigint | 用户id | |||
| refid | bigint | 商品id | |||
| tablename | varchar | 200 | 表名 | ||
| name | varchar | 200 | 名称 | ||
| picture | longtext | 4294967295 | 图片 | ||
| type | varchar | 200 | 类型(1:收藏,21:赞,22:踩,31:竞拍参与,41:关注) | 1 | |
| inteltype | varchar | 200 | 推荐类型 | ||
| remark | varchar | 200 | 备注 | 
表3-9:公告信息
| 字段名称 | 类型 | 长度 | 字段说明 | 主键 | 默认值 | 
| id | bigint | 主键 | 主键 | ||
| addtime | timestamp | 创建时间 | CURRENT_TIMESTAMP | ||
| title | varchar | 200 | 标题 | ||
| introduction | longtext | 4294967295 | 简介 | ||
| picture | longtext | 4294967295 | 图片 | ||
| content | longtext | 4294967295 | 内容 | 
表3-10:客房预定
| 字段名称 | 类型 | 长度 | 字段说明 | 主键 | 默认值 | 
| id | bigint | 主键 | 主键 | ||
| addtime | timestamp | 创建时间 | CURRENT_TIMESTAMP | ||
| yudingbianhao | varchar | 200 | 预定编号 | ||
| kefangmingcheng | varchar | 200 | 客房名称 | ||
| kefangleixing | varchar | 200 | 客房类型 | ||
| kefangzhuangtai | varchar | 200 | 客房状态 | ||
| kefangsheshi | varchar | 200 | 客房设施 | ||
| yudingtianshu | int | 预定天数 | |||
| kefangjiage | int | 客房价格 | |||
| zongjine | int | 总金额 | |||
| xiadanshijian | date | 下单时间 | |||
| yudingxiangqing | longtext | 4294967295 | 预定详情 | ||
| kehuzhanghao | varchar | 200 | 客户账号 | ||
| kehuxingming | varchar | 200 | 客户姓名 | ||
| shouji | varchar | 200 | 手机 | ||
| shenfenzheng | varchar | 200 | 身份证 | ||
| yuangonggonghao | varchar | 200 | 员工工号 | ||
| yuangongxingming | varchar | 200 | 员工姓名 | ||
| sfsh | varchar | 200 | 是否审核 | 待审核 | |
| shhf | longtext | 4294967295 | 审核回复 | ||
| ispay | varchar | 200 | 是否支付 | 未支付 | 
表3-11:客房入住
| 字段名称 | 类型 | 长度 | 字段说明 | 主键 | 默认值 | 
| id | bigint | 主键 | 主键 | ||
| addtime | timestamp | 创建时间 | CURRENT_TIMESTAMP | ||
| yudingbianhao | varchar | 200 | 预订编号 | ||
| kefangmingcheng | varchar | 200 | 客房名称 | ||
| kefangleixing | varchar | 200 | 客房类型 | ||
| kefanglouceng | varchar | 200 | 客房楼层 | ||
| ruzhushijian | datetime | 入住时间 | |||
| kehuzhanghao | varchar | 200 | 客户账号 | ||
| kehuxingming | varchar | 200 | 客户姓名 | ||
| shouji | varchar | 200 | 手机 | ||
| shenfenzheng | varchar | 200 | 身份证 | ||
| yuangonggonghao | varchar | 200 | 员工工号 | ||
| yuangongxingming | varchar | 200 | 员工姓名 | 
表3-12:员工
| 字段名称 | 类型 | 长度 | 字段说明 | 主键 | 默认值 | 
| id | bigint | 主键 | 主键 | ||
| addtime | timestamp | 创建时间 | CURRENT_TIMESTAMP | ||
| yuangonggonghao | varchar | 200 | 员工工号 | ||
| mima | varchar | 200 | 密码 | ||
| yuangongxingming | varchar | 200 | 员工姓名 | ||
| shouji | varchar | 200 | 手机 | ||
| touxiang | longtext | 4294967295 | 头像 | ||
| shenfenzheng | varchar | 200 | 身份证 | ||
| ruzhishijian | date | 入职时间 | |||
| zhiwei | varchar | 200 | 职位 | 
表3-13:清洁工
| 字段名称 | 类型 | 长度 | 字段说明 | 主键 | 默认值 | 
| id | bigint | 主键 | 主键 | ||
| addtime | timestamp | 创建时间 | CURRENT_TIMESTAMP | ||
| qingjiezhanghao | varchar | 200 | 清洁账号 | ||
| qingjiexingming | varchar | 200 | 清洁姓名 | ||
| touxiang | longtext | 4294967295 | 头像 | ||
| mima | varchar | 200 | 密码 | ||
| xingbie | varchar | 200 | 性别 | ||
| shouji | varchar | 200 | 手机 | 
表3-14:客户
| 字段名称 | 类型 | 长度 | 字段说明 | 主键 | 默认值 | 
| id | bigint | 主键 | 主键 | ||
| addtime | timestamp | 创建时间 | CURRENT_TIMESTAMP | ||
| kehuzhanghao | varchar | 200 | 客户账号 | ||
| kehuxingming | varchar | 200 | 客户姓名 | ||
| touxiang | longtext | 4294967295 | 头像 | ||
| mima | varchar | 200 | 密码 | ||
| xingbie | varchar | 200 | 性别 | ||
| shouji | varchar | 200 | 手机 | ||
| shenfenzheng | varchar | 200 | 身份证 | 
管理员功能模块
管理员通过登录页面填写用户名和密码,完成后进行登录,如图4-1所示。

管理员登录进入酒店客房管理系统的实现可以查看系统首页、个人中心、员工管理、清洁工管理、客户管理、客房类型管理、酒店客房管理、客房预定管理、客房入住管理、退房登记管理、系统管理等信息,如图4-2所示。

管理员点击客户管理;在客户管理页面对客户账号、客户姓名、头像、性别、手机、身份证等信息,进行查询,新增或删除客户信息等操作;如图4-3所示。

员工功能模块
登录界面,首先双击打开系统,连上网络之后会显示出本系统的登录界面,这是进入系统的第初始页面“登录”,能成功进入到该登录界面则代表系统的开启是成功的,接下来就可以操作本系统所带有的其他所有的功能,如图4-10所示。

员工登录系统后,可以对系统首页、个人中心、客房预定管理、客房入住管理、退房登记管理等功能进行相应操作,如图4-11所示。

清洁工功能模块
登录界面,首先双击打开系统,连上网络之后会显示出本系统的登录界面,这是进入系统的第初始页面“登录”,能成功进入到该登录界面则代表系统的开启是成功的,接下来就可以操作本系统所带有的其他所有的功能,如图4-12所示。

结 论
酒店客房管理系统通过 springboot框架、JAVA语言等技术完成的。系统可以完成用户的基本需求,并且在测试中系统运行情况良好,没有出现异常。但是,还是有许多我需要学习和完善的地方。
酒店客房管理系统实现了模块化连接,对应不同的平台可以进行针对性部署,可以进行全方位的覆盖。它实现了跨终端无缝协同体验。但碍于酒店客房管理系统刚进入市场发行不久,它的各项数据,功能还没有达到完美的地步。需要进一步的实际运行来完善有缺陷的地方。在这个信息化的时代大家都希望手里的任何一个电子设备都可以完成平时的常见功能,通过酒店客房管理系统的开发可以实现这一目标。酒店客房管理系统作为国产系统,它的发展前途十分明亮,未来也会拥有很广泛的市场,通过未来的长时间发展,酒店客房管理系统的软件开发一定会成为一种趋势,让中国的操作系统发展得到进一步的提升。
