基于Java+Spring+mybatis+vue+element实现酒店管理系统

博主介绍全网粉丝20W+,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,CSDN博客之星TOP100、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业设计

 🍅文末获取联系🍅

   精彩专栏推荐👇🏻👇🏻👇🏻👇🏻
java项目精品实战案例《100套》https://blog.csdn.net/weixin_39709134/category_11128297.html

 前言介绍: 

以往的酒店管理系统相关信息管理,都是工作人员手工统计。这种方式不但时效性低,而且需要查找和变更的时候很不方便。随着科学的进步,技术的成熟,计算机信息化也日新月异的发展,如今计算机已经进入了人类社会发展的各个领域,并且发挥着十分重要的作用。本系统充分利用网络的便捷,在工作效率上,得到极大地提高,延伸至服务水平也会有好的收获,有了网络,酒店管理系统的各方面的管理更加科学和系统,更加规范和简便。用户提供酒店管理系统,方便管理员及时高效的管理所有的信息,给用户提供简单方便快捷的方式,并且数据准确,用户可以足不出户就可以对酒店管理系统相关信息进行查询等操作,而且还能节省用户查询信息的等待时间,所以开发酒店管理系统给工作人员带来很大的方便,可以大大的提高系统人员工作效率。

系统设计:

主要功能模块设计 

酒店管理系统采用B/S结构、java开发语言、以及Mysql数据库等技术。系统主要分为管理员和用户二部分,管理员:首页、个人中心、用户管理、客房类型管理、客房信息管理客房预订管理、入住登记管理、退房评价管理、系统管理,用户;首页、个人中心、客房预订管理、入住登记管理、点餐管理、退房评价管理、我的收藏管理,前台首页;首页、客房信息、酒店公告、个人中心、后台管理、在线咨询等功能,基本上实现了整个酒店管理系统信息管理的过程。本系统在一般酒店管理系统的基础上增加了最新信息的功能方便用户快速浏览,是一个高效的、动态的、互友好的酒店管理系统

​​

用户登录注册时序图

前端用户发送登录请求-验证输入的账号虚线-执行数据查询-返回查询结果-判断用户是否存在-前端根据结果集执行不同的操作 

功能截图:

登陆注册:

用户登录、用户注册,在注册页面可以填写用户名、密码、姓名、联系电话、身份证信息进行注册、登录

系统前端:

系统首页:

酒店信息:

客房信息:

客房预定:

餐饮下单:

酒店餐饮:

酒店资讯:

个人中心:

用户登录、用户注册,在注册页面可以填写用户名、密码、姓名、联系电话、身份证信息进行注册、登录

客服信息:

 用户后台管理:

系统后端:

个人信息:

客房分类:

客房类型管理页面可以查看客房类型等信息,并可根据需要进行删除,修改等操作

酒店信息:

 编辑修改等

酒店餐饮:

用户管理:

客房预订:

客房续房:

退房评价:

餐饮订单:

餐饮配送:

轮播图管理:

酒店资讯:

数据设计:

在该系统的信息中,由于数据库的支持,我们可以对数据库进行收集、整理、更新和加工等操作。由于数据库的存储功能强大,所以数据库已经成为了计算机必不可少的一部分,一个数据库的好坏直接影响该系统的质量和效率。一个系统中的数据库是必不可少的,并且起着决定性因素。通过之前的系统分析,可以规划出本系统中使用的主要等,下面设计出这几个关键实体的实体关系图:

(1)用户信息实体E-R图如图所示:

​​(2)客房信息实体E-R图如图所示:

 (3)入住登记信息实体E- R图,如图所示:

代码实现:

/*** 酒店餐饮* 后端接口* @author * @email * @date 2022-01-11 13:23:20*/
@RestController
@RequestMapping("/jiudiancanyin")
public class JiudiancanyinController {@Autowiredprivate JiudiancanyinService jiudiancanyinService;/*** 后端列表*/@RequestMapping("/page")public R page(@RequestParam Map<String, Object> params,JiudiancanyinEntity jiudiancanyin, HttpServletRequest request){EntityWrapper<JiudiancanyinEntity> ew = new EntityWrapper<JiudiancanyinEntity>();PageUtils page = jiudiancanyinService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jiudiancanyin), params), params));return R.ok().put("data", page);}/*** 前端列表*/@IgnoreAuth@RequestMapping("/list")public R list(@RequestParam Map<String, Object> params,JiudiancanyinEntity jiudiancanyin, HttpServletRequest request){EntityWrapper<JiudiancanyinEntity> ew = new EntityWrapper<JiudiancanyinEntity>();PageUtils page = jiudiancanyinService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jiudiancanyin), params), params));return R.ok().put("data", page);}/*** 列表*/@RequestMapping("/lists")public R list( JiudiancanyinEntity jiudiancanyin){EntityWrapper<JiudiancanyinEntity> ew = new EntityWrapper<JiudiancanyinEntity>();ew.allEq(MPUtil.allEQMapPre( jiudiancanyin, "jiudiancanyin")); return R.ok().put("data", jiudiancanyinService.selectListView(ew));}/*** 查询*/@RequestMapping("/query")public R query(JiudiancanyinEntity jiudiancanyin){EntityWrapper< JiudiancanyinEntity> ew = new EntityWrapper< JiudiancanyinEntity>();ew.allEq(MPUtil.allEQMapPre( jiudiancanyin, "jiudiancanyin")); JiudiancanyinView jiudiancanyinView =  jiudiancanyinService.selectView(ew);return R.ok("查询酒店餐饮成功").put("data", jiudiancanyinView);}/*** 后端详情*/@RequestMapping("/info/{id}")public R info(@PathVariable("id") String id){JiudiancanyinEntity jiudiancanyin = jiudiancanyinService.selectById(id);return R.ok().put("data", jiudiancanyin);}/*** 前端详情*/@IgnoreAuth@RequestMapping("/detail/{id}")public R detail(@PathVariable("id") String id){JiudiancanyinEntity jiudiancanyin = jiudiancanyinService.selectById(id);return R.ok().put("data", jiudiancanyin);}/*** 后端保存*/@RequestMapping("/save")public R save(@RequestBody JiudiancanyinEntity jiudiancanyin, HttpServletRequest request){jiudiancanyin.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(jiudiancanyin);jiudiancanyinService.insert(jiudiancanyin);return R.ok();}/*** 前端保存*/@RequestMapping("/add")public R add(@RequestBody JiudiancanyinEntity jiudiancanyin, HttpServletRequest request){jiudiancanyin.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(jiudiancanyin);jiudiancanyinService.insert(jiudiancanyin);return R.ok();}/*** 修改*/@RequestMapping("/update")public R update(@RequestBody JiudiancanyinEntity jiudiancanyin, HttpServletRequest request){//ValidatorUtils.validateEntity(jiudiancanyin);jiudiancanyinService.updateById(jiudiancanyin);//全部更新return R.ok();}/*** 删除*/@RequestMapping("/delete")public R delete(@RequestBody Long[] ids){jiudiancanyinService.deleteBatchIds(Arrays.asList(ids));return R.ok();}/*** 提醒接口*/@RequestMapping("/remind/{columnName}/{type}")public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request, @PathVariable("type") String type,@RequestParam Map<String, Object> map) {map.put("column", columnName);map.put("type", type);if(type.equals("2")) {SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");Calendar c = Calendar.getInstance();Date remindStartDate = null;Date remindEndDate = null;if(map.get("remindstart")!=null) {Integer remindStart = Integer.parseInt(map.get("remindstart").toString());c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindStart);remindStartDate = c.getTime();map.put("remindstart", sdf.format(remindStartDate));}if(map.get("remindend")!=null) {Integer remindEnd = Integer.parseInt(map.get("remindend").toString());c.setTime(new Date());c.add(Calendar.DAY_OF_MONTH,remindEnd);remindEndDate = c.getTime();map.put("remindend", sdf.format(remindEndDate));}}Wrapper<JiudiancanyinEntity> wrapper = new EntityWrapper<JiudiancanyinEntity>();if(map.get("remindstart")!=null) {wrapper.ge(columnName, map.get("remindstart"));}if(map.get("remindend")!=null) {wrapper.le(columnName, map.get("remindend"));}int count = jiudiancanyinService.selectCount(wrapper);return R.ok().put("count", count);}}

@Service("chatService")
public class ChatServiceImpl extends ServiceImpl<ChatDao, ChatEntity> implements ChatService {@Overridepublic PageUtils queryPage(Map<String, Object> params) {Page<ChatEntity> page = this.selectPage(new Query<ChatEntity>(params).getPage(),new EntityWrapper<ChatEntity>());return new PageUtils(page);}@Overridepublic PageUtils queryPage(Map<String, Object> params, Wrapper<ChatEntity> wrapper) {Page<ChatView> page =new Query<ChatView>(params).getPage();page.setRecords(baseMapper.selectListView(page,wrapper));PageUtils pageUtil = new PageUtils(page);return pageUtil;}@Overridepublic List<ChatVO> selectListVO(Wrapper<ChatEntity> wrapper) {return baseMapper.selectListVO(wrapper);}@Overridepublic ChatVO selectVO(Wrapper<ChatEntity> wrapper) {return baseMapper.selectVO(wrapper);}@Overridepublic List<ChatView> selectListView(Wrapper<ChatEntity> wrapper) {return baseMapper.selectListView(wrapper);}@Overridepublic ChatView selectView(Wrapper<ChatEntity> wrapper) {return baseMapper.selectView(wrapper);}}

论文参考:

​​

源码获取:

大家点赞、收藏、关注、评论啦 、查看👇🏻👇🏻👇🏻获取联系方式👇🏻👇🏻👇🏻

打卡 文章 更新 298/  365天

 精彩专栏推荐订阅:下方专栏👇🏻👇🏻👇🏻👇🏻

Java项目精品实战案例《100套》

web前端期末大作业网页实战《100套》

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/561722.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MyBatis批量插入为什么比单条插入块?

今天在利用excel处理业务数据的时候开始打算一条一条插入数据库&#xff01;因为要做数据校验和数据保存返回id之后进行其他表也插入&#xff01;大约有30000多条数据库吧&#xff01;花了大约3-5分钟&#xff0c;前端也会出现超时请求问题、让我意识到一条一条插入影响性能&am…

javaList<Map<String, Object>>升序、降序

降序&#xff1a; static class MapComparatorDesc implements Comparator<Map<String, Object>> {Overridepublic int compare(Map<String, Object> m1, Map<String, Object> m2) {Double v1 Double.valueOf(m1.get("avgScore").toString(…

无语!Jenkins 也宣布弃用 Java 8

继Java 之父 James Gosling 先前称&#xff0c;开发者应尽快弃用 JDK 8&#xff0c;可以选择 JDK 17 LTS&#xff0c;因为后者在各个方面都带来了巨大的改进。 开源 Devops 工具 Jenkins 宣布&#xff1a;从 6 月 28 日发布的 Jenkins 2.357 和即将发布的 9 月 LTS 版本开始&am…

(2022最新)Java毕业设计参考题目-题目新颖(值得收藏)

前言介绍 博主介绍&#xff1a;✌全网粉丝20W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星TOP100、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业设计项目实战✌ &#x1f345;文末获取联系&#x1f345; 大四的同学马上要开…

Java实现二维码的生成和解析

最近因个人需求需要对根据内容生成二维码和进行解析&#xff01;记录一下&#xff01;二维码其实就是一种编码技术&#xff0c;只是这种编码技术是用在图片上了&#xff0c;将给定的一些文字&#xff0c;数字转换为一张经过特定编码的图片。这里利用的是 google 公司的 zxing使…

Java利用TimerTask执行一次定时任务

项目有个简单的小需求就是在考试时间结束后把待考的用户状态修改为缺考&#xff0c;可以利用TimerTask来实现&#xff0c;在java中实现定时执行任务的功能&#xff0c;主要用到Timer和TimerTask类。其中Timer是用来在一个后台线程按指定的计划来执行指定的任务。 在新增考试的…

Java Date 类型时间运算,对年做减法运算计算工龄得分

/*** 工龄折算分数* 1.1.1小学&#xff1a;记60分结合折算0.54分* 1.1.2初中&#xff1a;记70分结合折算0.63分* 1.1.3中专&#xff08;高中&#xff09;&#xff1a;记80分结合折算0.72分* 1.1.4大专&#xff1a;记90分结合折算0.81分* 1.1.5本科&#xff08;及以上&#xff0…

MYSQL求2个参数之间的正确率百分比

根据相应条件统计需要的count 查询总count数(totalCount) 计算百分比&#xff1a;count / totalCount * 100 表设计&#xff1a; CREATE TABLE topic_exercise (id bigint(11) NOT NULL,topic_id bigint(11) NOT NULL COMMENT 试题id,user_id bigint(11) NOT NULL COMMENT 用户…

2022年十大接口测试工具合集《建议.收藏》

接口测试的全称是应用程序编程接口&#xff08;API&#xff09;测试&#xff0c;从原理上来说&#xff0c;接口测试是模拟客户端向服务器端发送请求&#xff0c;然后检查能否获得正确的返回信息。接口测试用于测试RESTful API、SOAP Web服务&#xff0c;这些服务可以通过HTTP、…

Web前端期末大作业--马尔代夫旅游网页设计(HTML+CSS+JavaScript+)实现

&#x1f345; 作者主页&#xff1a;Java李杨勇 &#x1f345; 简介&#xff1a;Java领域优质创作者&#x1f3c6;、【java李阳勇】公号作者✌ 简历模板、学习资料、面试题库、技术互助【关注我&#xff0c;都给你】 &#x1f345; 欢迎点赞 &#x1f44d; 收藏 ⭐留言 &…

基于Java-SpringBoot+vue实现的前后端分离信息管理系统设计和实现

&#x1f345; 作者主页&#xff1a;Java李杨勇 &#x1f345; 简介&#xff1a;Java领域优质创作者&#x1f3c6;、【java李阳勇】公号作者✌ 简历模板、学习资料、面试题库【关注我&#xff0c;都给你】 &#x1f345;文末获取源码联系&#x1f345; 前言&#xff1a; 当…

IDEA 启动项目报错 Unable to make field private com.sun.tools.javac.processing.JavacProcessingE

今天帮同学部署项目报错&#xff1a; Unable to make field private com.sun.tools.javac.processing.JavacProcessingEnvironment$Discovere 原因是因为JDK版本太高与项目中使用的jdk版本不对应&#xff0c;修改Project SDK版本就行了

Java List集合计算排名,相同分数名次一样

思路: 按照用户成绩分数来进行排名.&#xff0c;在然后排名的时候进行比较. 如果这一名的用户成绩分数和上一名的相同, 那么名次相同, 如果比上一名分数低,那么排名加一 。 //该方法可用于分数成绩排名计算操作//传入需要处理的用户成绩集合和分数public int getClassRank(Lis…

ORACLE 12C切换至可插入式数据库命令

第一步&#xff1a;以管理员身份进行登陆&#xff1a; sqlplus / as sysdba 第二步&#xff1a;打开可插拔数据库 alter pluggable database pdborcl open; 第二步&#xff1a;切换至可插拔数据库 alter session set containerpdborcl;

oracle 12C提示:ORA-28001口令已经失效

很久没有登录oracle了&#xff0c;过了一段时间提示口令失效&#xff0c;解决方法是打开cmd命令窗口执行以下命令。 系统管理员身份登陆:sqlplus / as sysdba转到对应的pdb容器中: alter session set containerorclpdb;修改密码:alter user 用户名 identified by 密码;

MySQL连接navicat出现 2059 - authentication plugin ‘caching_sha2_password解决方法

今天给同学部署项目的时候用navicat登录的时候报错&#xff1a;2059 - authentication plugin caching_sha2_password解决方法。 出现的原因是&#xff1a;mysql8之前版本中加密规则为mysql_native_password mysql8以后的加密规则为caching_sha2_password 将mysql用户登录加密规…

tomcat启动报错javax.servlet.ServletException: It is not allowed to configure supportsCredentials=[true]

今天突然接手一个万年JSP SSM的老项目&#xff0c;在项目启动 tomcat报错javax.servlet.ServletException: It is not allowed to configure supportsCredentials[true] when allowedOrigins[*]。报错信息很明显 就是cors.allowed.origins * 和cors.support.credentialstrue冲突…

HBuilderX预编译器错误:代码使用了scss/sass语言,但未安装相应的编译器插件,请前往插件市场安装该插件:

预编译器错误&#xff1a;代码使用了scss/sass语言&#xff0c;但未安装相应的编译器插件&#xff0c;请前往插件市场安装该插件。 解决方法&#xff1a;打开HBuilder&#xff0c;点击工具选项&#xff0c;然后点击插件安装就可以了 直接下载之后解压到 HBuilderX--plugins里面…

Java菜单树递归

主要实现思路 1.首先从菜单数据中获取所有根节点。 2.为根节点建立次级子树并拼接上。 3.递归为子节点建立次级子树并接上&#xff0c;直至为末端节点拼接上空的“树”。 数据表设计&#xff1a; CREATE TABLE menu (id bigint(20) unsigned NOT NULL COMMENT 主键,name v…

使用OBS录屏有很大的电流回声

最近换了耳机之后用OBS录屏有很大的噪音回事&#xff0c;在网上通过各种设置后还是没有解决。 最后发现电流声是由麦克风引起的&#xff0c;以前的耳机只有一个插口没注意这些也没有发生过这种情况。 现在买的新耳机是两根线&#xff0c;麦克风和耳机&#xff0c;把麦克风的那…