Java项目:30 基于SpringBoot自习室座位预定系统

news/发布时间2024/9/20 8:16:02
作者主页:舒克日记

简介:Java领域优质创作者、Java项目、学习资料、技术互助

文中获取源码

项目介绍

功能设计
管理员

1、用户管理

管理员可以新增、删除管理员

管理员可以删除学生

2、自习室管理

管理员可以新增自习室、设置自习室的座位数量、开放时间,对自习室进行管理

管理员可以管理学生的预订情况、可以强制退订

3、学院班级管理

管理员可以新增、修改、删除学院、班级(实际上这部分数据应该来源于教务系统)

4、个人管理

管理员可以对自己信息进行修改

学生

1、自习室管理

学生可以查看自习室座位的预定情况并进行预定

学生可以查看自己的预定情况,并退订

2、个人信息管理

学生可以修改自己的用户信息

点击查看演示视频

环境要求

1.运行环境:最好是java jdk1.8,我们在这个平台上运行的。其他版本理论上也可以。

2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA;

3.tomcat环境:Tomcat7.x,8.X,9.x版本均可

4.硬件环境:windows7/8/10 4G内存以上;或者Mac OS;

5.是否Maven项目:是;查看源码目录中是否包含pom.xml;若包含,则为maven项目,否则为非maven.项目

6.数据库:MySql5.7/8.0等版本均可;

技术栈

  • MySQL5.7

  • Idea2020.3

  • SpringBoot、Mybatis-plus、thymeleaf

  • layui、jquery、xadmin

使用说明

1.使用Navicati或者其它工具,在mysql中创建对应sq文件名称的数据库,并导入项目的sql文件;

2.使用IDEA/Eclipse/MyEclipse导入项目,修改配置,运行项目;

3.将项目中config-propertiesi配置文件中的数据库配置改为自己的配置,然后运行;

运行指导

idea导入源码空间站顶目教程说明(Vindows版)-ssm篇:

http://mtw.so/5MHvZq

源码地址:http://codegym.top

运行截图

前端界面

登录/注册页面

微信截图_20240228005946

微信截图_20240228010030

管理员界面

微信截图_20240228011135

微信截图_20240228011216

微信截图_20240228011222

微信截图_20240228011231

微信截图_20240228011237

微信截图_20240228011130

学生界面

微信截图_20240228011314

微信截图_20240228011321

微信截图_20240228011321

代码

SeatServiceImpl

package com.cxs.service.impl;import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.cxs.dto.ReservationSeatDTO;
import com.cxs.enums.ReservationMarkEnums;
import com.cxs.mapper.ClassroomMapper;
import com.cxs.mapper.ClazzMapper;
import com.cxs.mapper.SeatOrderMapper;
import com.cxs.mapper.StudentMapper;
import com.cxs.model.Classroom;
import com.cxs.model.Seat;
import com.cxs.model.SeatOrder;
import com.cxs.model.Student;
import com.cxs.service.SeatService;
import com.cxs.mapper.SeatMapper;
import com.cxs.sourceBo.ClazzBo;
import com.cxs.sourceBo.SeatBo;
import com.cxs.sourceBo.SeatOrderBo;
import com.cxs.vo.ReservationMarkVO;
import com.cxs.vo.Result;
import com.cxs.vo.SeatOrderDetailVO;
import com.cxs.vo.SeatOrderInfoVO;
import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.util.CollectionUtils;import java.lang.annotation.ElementType;
import java.time.DayOfWeek;
import java.time.Duration;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.LocalTime;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.function.Function;
import java.util.stream.Collectors;/**
* @author DELL
* @description 针对表【t_seat(座位表)】的数据库操作Service实现
* @createDate 2023-11-28 10:44:22
*/
@Service
public class SeatServiceImpl extends ServiceImpl<SeatMapper, Seat>implements SeatService{@Autowiredprivate SeatMapper seatMapper;@Autowiredprivate ClassroomMapper classroomMapper;@Autowiredprivate SeatOrderMapper seatOrderMapper;@Autowiredprivate StudentMapper studentMapper;@Autowiredprivate ClazzMapper clazzMapper;@Overridepublic List<SeatOrderInfoVO> getSeatListInfo(Integer id, LocalDate date) {List<SeatOrderInfoVO> childList = new ArrayList<>();SeatBo bo = seatMapper.selectOrderInfoBySeatId(id, date);if (null == bo) {Seat seat = seatMapper.selectById(id);bo = new SeatBo();BeanUtils.copyProperties(seat, bo);}Classroom classroom = classroomMapper.selectById(bo.getClassroomId());int start = classroom.getOpenTimeStart().getHour();int end = classroom.getOpenTimeEnd().getHour();List<SeatOrder> orderList = bo.getOrderList();Map<String,SeatOrder> orderMap =  CollectionUtils.isEmpty(orderList) ? new HashMap<>() : orderList.stream().collect(Collectors.toMap(SeatOrder::getReservationMark, Function.identity(), (o1, o2) -> o1));List<ReservationMarkVO> reservationMarkVOList = ReservationMarkEnums.getReservationMarkVOList(start, end);for (ReservationMarkVO reservationMarkVO : reservationMarkVOList) {SeatOrderInfoVO v = new SeatOrderInfoVO();v.setSeatId(bo.getId());v.setReservationMark(reservationMarkVO.getMark());v.setTimeRange(reservationMarkVO.getTimeRange());v.setSno(bo.getSeatNo());SeatOrder seatOrder = orderMap.get(reservationMarkVO.getMark());if (null != seatOrder) {v.setCreateTime(seatOrder.getCreateTime());v.setFlag(Boolean.TRUE);v.setId(seatOrder.getId());} else {v.setFlag(Boolean.FALSE);}childList.add(v);}return childList;}@Overridepublic void getSeatOrderInfo(Integer id, Result r) {if (null == id) {r.setCode(-1);r.setMsg("id不能为空");return;}SeatOrder seatOrder = seatOrderMapper.selectById(id);if (null == seatOrder) {r.setCode(-1);r.setMsg("预定不存在");return;}Seat seat = seatMapper.selectById(seatOrder.getSeatId());if (null == seat) {r.setCode(-1);r.setMsg("座位不存在");return;}Classroom classroom = classroomMapper.selectById(seat.getClassroomId());if (null == classroom) {r.setCode(-1);r.setMsg("自习室不存在");return;}Student student = studentMapper.selectById(seatOrder.getSno());ClazzBo info = clazzMapper.getClazzInfoByClazzId(student.getClazzId());List<ReservationMarkVO> reservationMarkVOList = ReservationMarkEnums.getReservationMarkVOList(classroom.getOpenTimeStart().getHour(), classroom.getOpenTimeEnd().getHour());Map<String, ReservationMarkVO> map = CollectionUtils.isEmpty(reservationMarkVOList) ? new HashMap<>() : reservationMarkVOList.stream().collect(Collectors.toMap(ReservationMarkVO::getMark, Function.identity(), (o1, o2) -> o1));SeatOrderDetailVO vo = new SeatOrderDetailVO();BeanUtils.copyProperties(seatOrder, vo);vo.setName(student.getName());vo.setPhone(student.getPhone());vo.setSex(student.getSex());ReservationMarkVO reservationMarkVO = map.get(seatOrder.getReservationMark());if (null != reservationMarkVO) {vo.setTimeRange(reservationMarkVO.getTimeRange());}vo.setCollageName(info.getGradeName());vo.setClazzName(info.getClazzName());r.setData(vo);}@Overridepublic void reservationSeat(ReservationSeatDTO dto, Integer sno, Result r) {LocalDate date = dto.getDate();LocalDate now = LocalDate.now();if (date.isBefore(now)) {r.setCode(-1);r.setMsg("该时间不可预约座位");return;}if (Duration.between(LocalDateTime.of(now, LocalTime.MIN), LocalDateTime.of(date, LocalTime.MIN)).toDays() > 7L) {r.setCode(-1);r.setMsg("仅支持预定一周内的座位");return;}LambdaQueryWrapper<SeatOrder> queryWrapper = new LambdaQueryWrapper<>();queryWrapper.eq(SeatOrder::getReservationMark, dto.getMark()).eq(SeatOrder::getDate, dto.getDate()).eq(SeatOrder::getSno, sno);List<SeatOrder> seatOrders = seatOrderMapper.selectList(queryWrapper);if (!CollectionUtils.isEmpty(seatOrders)) {r.setCode(-1);r.setMsg("预定失败,该时间段内您已进行预定座位,请按时去学习,把座位留给需要的同学,谢谢!");return;}Seat seat = seatMapper.selectById(dto.getSeatId());if (null == seat) {r.setCode(-1);r.setMsg("座位不存在");return;}Classroom classroom = classroomMapper.selectById(seat.getClassroomId());if (null == classroom) {r.setCode(-1);r.setMsg("自习室不存在");return;}Integer openType = classroom.getOpenType();// 0每天开放,1工作日开放2休息日开放DayOfWeek dayOfWeek = date.getDayOfWeek();if (openType == 0) {} else if (openType == 1) {if (dayOfWeek.equals(DayOfWeek.SATURDAY) || dayOfWeek.equals(DayOfWeek.SUNDAY)) {r.setCode(-1);r.setMsg(classroom.getName() + "自习室" + "仅工作日可定");return;}} else if (openType == 2) {if (!dayOfWeek.equals(DayOfWeek.SATURDAY) && !dayOfWeek.equals(DayOfWeek.SUNDAY)) {r.setCode(-1);r.setMsg(classroom.getName() + "自习室" + "仅休息日可定");return;}} else {r.setCode(-1);r.setMsg("自习室开放时间有误");return;}List<ReservationMarkVO> reservationMarkVOList = ReservationMarkEnums.getReservationMarkVOList(classroom.getOpenTimeStart().getHour(), classroom.getOpenTimeEnd().getHour());Map<String, ReservationMarkVO> map = CollectionUtils.isEmpty(reservationMarkVOList) ? new HashMap<>() : reservationMarkVOList.stream().collect(Collectors.toMap(ReservationMarkVO::getMark, Function.identity(), (o1, o2) -> o1));SeatOrder order = new SeatOrder();order.setSeatId(dto.getSeatId());order.setCreateTime(LocalDateTime.now());order.setDate(dto.getDate());ReservationMarkVO reservationMarkVO = map.get(dto.getMark());if (reservationMarkVO == null) {r.setCode(-1);r.setMsg("预约时间有误");return;}int hour = LocalDateTime.now().getHour();if (date.equals(now)) {if (reservationMarkVO.getStartTime() < hour) {r.setCode(-1);r.setMsg("当前时间不可预订,请选择其他时间预定");return;}}order.setReservationMark(dto.getMark());order.setStartTime(reservationMarkVO.getStartTime());order.setEndTime(reservationMarkVO.getEndTime());order.setSno(sno);int insert = seatOrderMapper.insert(order);if (insert != 1) {r.setCode(-1);r.setMsg("预约失败");return;}}
}

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

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

相关文章

lnmp安装

一、安装lnmp 第一步&#xff1a;将MySQL 、论坛的安装包拖进shell 环境准备 lnmp 需要 安装 nginx mysql php 软件 第二步&#xff1a;解压nginx&#xff0c;再安装依赖包&#xff08;注意装在源配置文件下&#xff09;&#xff0c;关闭防火墙 systemctl disable --now fir…

map和set的简单介绍

由于博主的能力有限&#xff0c;所以为了方便大家对于map和set的学习&#xff0c;我放一个官方的map和set的链接供大家参考&#xff1a; https://cplusplus.com/ 在初阶阶段&#xff0c;我们已经接触过STL中的部分容器&#xff0c;比如&#xff1a;vector、list、deque&#x…

Redis 在 Linux 系统下安装部署的两种方式详细说明

小伙伴们好&#xff0c;欢迎关注&#xff0c;一起学习&#xff0c;无限进步 Redis安装和配置 1、首先在官网下载好redis-6.0.9.tar.gzhttp://redis.io/ 或者使用 wget 命令下载&#xff1a;wget http://download.redis.io/releases/redis-6.0.9.tar.gz 2、下载使用上传到阿里…

【小沐学QT】QT学习之信号槽使用

文章目录 1、简介2、代码实现2.1 界面菜单“转到槽”方法2.2 界面信号槽编辑器方法2.3 QT4.0的绑定方法2.4 QT5.0之后的绑定方法2.5 C11的方法2.6 lamda表达式方法2.7 QSignalMapper方法 结语 1、简介 在GUI编程中&#xff0c;当我们更改一个小部件时&#xff0c;我们通常希望…

[SpringDataMongodb开发游戏服务器实战]

背景&#xff1a; xdb其实足够完美了&#xff0c;现在回想一下&#xff0c;觉得有点复杂&#xff0c;我们不应该绑定语言&#xff0c;最好有自己的架构思路。 七号堡垒作为成功的商业项目&#xff0c;告诉我&#xff1a;其实数据是多读少写的&#xff0c;有修改的时候直接改库也…

4核8g服务器能支持多少人访问?

腾讯云4核8G服务器支持多少人在线访问&#xff1f;支持25人同时访问。实际上程序效率不同支持人数在线人数不同&#xff0c;公网带宽也是影响4核8G服务器并发数的一大因素&#xff0c;假设公网带宽太小&#xff0c;流量直接卡在入口&#xff0c;4核8G配置的CPU内存也会造成计算…

前端 基础标签

!回车在vscode中可以生成简单的代码模板 注释 ctrl/ <h1></h1> 类似的数字越大字体越小 <p></p>表示一个段落 注:这里的回车会被解析成空格 <br> 单标签 表示换行 格式化标签 加粗标签 <strong></strong> <b></b> …

常用对象的遍历方法

var obj [{name: 1111,account: {01: { name: 1.1 },02: { name: 1.2 },03: { name: 1.3 },04: { name: 1.4 },05: { name: 1.5 },}} ]var nowObj obj[0].account;1、for…in 任意顺序遍历对象所有的可枚举属性&#xff08;包括对象自身的和继承的可枚举属性&#xff0c;不含…

前端-Vue3递归组件自定义Tree

需求 PS&#xff1a;写在前面&#xff0c;需求想要一个Tree 形结构展示当前的组织机构&#xff0c;最末层节点可以选择&#xff0c;层级明确。第一选择网上npm官网或者github 找找成型的东西 element-ui Tree 没有组织结构线js-tree 好看&#xff0c;但是适配Vue3 有点费劲&a…

Appium手机Android自动化

目录 介绍 什么是APPium&#xff1f; APPium的特点 环境准备 adb(android调试桥)常用命令 appium图形化简单使用 连接手机模拟器 使用appium桌面端应用程序 ​编辑 整合java代码测试 环境准备 引入所需依赖 书写代码简单启动 ​编辑 Appium元素定位 id定位 介…

【postgresql】数据表id自增与python sqlachemy结合实例

需求&#xff1a; postgresql实现一个建表语句&#xff0c;表名&#xff1a;student,字段id,name,age&#xff0c; 要求&#xff1a;每次添加一个数据id会自动增加1 在PostgreSQL中&#xff0c;您可以使用SERIAL或BIGSERIAL数据类型来自动生成主键ID。以下是一个创建名为stude…

Ubuntu系统下DPDK环境搭建

目录 一.虚拟机配置1.添加一个网卡(桥接模式)2.修改网卡类型3.修改网卡名称4.重启虚拟机5.查看网卡信息6.dpdk配置内存巨型页 三 DPDK源代码下载和编译1.下载源代码2.解压源代码3.安装编译环境4.编译5.设置dpdk的环境变量6.禁止多队列网卡7.加载igb_uio模块8.网卡绑定9.验证测试…

数据分类分级场景建设思路

数据分类分级是数据安全治理实践过程中的关键场景&#xff0c;是数据安全工作的桥头堡和必选题。本指南结合行业实践&#xff0c;提出如下图 所示的七步走建设思路&#xff0c;可供刚开展数据分类分级工作的组织参考。 来源&#xff1a;中国信息通信研究院 数据分类分级“七步…

PyTorch概述(七)---Optim

torch.optim是一个实现多种优化算法的包;很多常用的方法已经被支持;接口丰富;容易整合更为复杂的算法; 如何使用一个优化器 为了使用torch.optim包功能;用户必须构建一个优化器对象;该优化器将保持当前的参数状态且基于计算的梯度更新参数; 构建优化器 要构建一个优化器;必…

SD-WAN技术:优化国内外服务器访问的关键

在全球化的商业环境中&#xff0c;企业经常需要在国内访问国外的服务器。然而&#xff0c;由于地理位置和网络架构的限制&#xff0c;这种跨国访问往往会遇到速度慢、延迟高等问题。SD-WAN&#xff08;软件定义广域网&#xff09;技术的兴起&#xff0c;为企业提供了一种新的解…

【MATLAB源码-第148期】基于matlab的BP神经网络2/4ASK,2/4FSK,2/4PSK信号识别仿真。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 1. 调制技术基础 调制技术是通信技术中的基础&#xff0c;它允许数据通过无线电波或其他形式的信号进行传输。调制可以根据信号的振幅、频率或相位的变化来进行&#xff0c;分别对应于ASK、FSK和PSK。 1.1 2ASK与4ASK 振幅…

技术派数据库表自动初始化(学习)

不需要在db中手动创建或者导入相关的schema、data&#xff0c;项目启动自动创建对应的表&#xff0c;并初始化。实现该过程。 Liquibase数据库版本管理 依赖配置 在paicoding-web模块中&#xff0c;pom.xml 文件中添加 <dependency><groupId>org.liquibase</g…

音视频数字化(数字与模拟-电视)

上一篇文章【音视频数字化(数字与模拟-音频广播)】谈了音频的广播,这次我们聊电视系统,这是音频+视频的采集、传输、接收系统,相对比较复杂。 音频系统的广播是将声音转为电信号,再调制后发射出去,利用“共振”原理,收音机接收后解调,将音频信号还原再推动扬声器,我…

力扣链表篇

以下刷题思路来自代码随想录以及官方题解 文章目录 203.移除链表元素707.设计链表206.反转链表24.两两交换链表中的节点19.删除链表的倒数第N个节点面试题 02.07. 链表相交142.环形链表II 203.移除链表元素 给你一个链表的头节点 head 和一个整数 val &#xff0c;请你删除链…

wcf 简单实践 数据绑定 数据更新ui

1.概要 2.代码 2.1 xaml <Window x:Class"WpfApp3.MainWindow"xmlns"http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x"http://schemas.microsoft.com/winfx/2006/xaml"xmlns:d"http://schemas.microsoft.com/expr…
推荐文章