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

作者主页:源码空间codegym

简介: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{

    @Autowired
    private SeatMapper seatMapper;

    @Autowired
    private ClassroomMapper classroomMapper;

    @Autowired
    private SeatOrderMapper seatOrderMapper;

    @Autowired
    private StudentMapper studentMapper;

    @Autowired
    private ClazzMapper clazzMapper;

    @Override
    public 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;
    }

    @Override
    public 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);
    }

    @Override
    public 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.mfbz.cn/a/424202.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

关于福彩历史数据采集器和体彩历史数据采集器的下载安装说明

前段时间因为研究基于人工神经网络&#xff08;深度学习&#xff0c;所谓的“AI”算法&#xff09;对3D开奖数据进行预测&#xff0c;开发了两款浏览器插件----“福彩历史数据采集器”和“体彩历史数据采集器”。之所以开发这两款插件&#xff0c;是因为不管是基于什么样的方式…

机器学习:集成学习(Python)

一、Adaboost算法 1.1 Adaboost分类算法 adaboost_discrete_c.py import numpy as np import copy from ch4.decision_tree_C import DecisionTreeClassifierclass AdaBoostClassifier:"""adaboost分类算法&#xff1a;既可以做二分类、也可以做多分类&#…

缓存相关问题:雪崩、穿透、预热、更新、降级的深度解析

✨✨祝屏幕前的小伙伴们每天都有好运相伴左右✨✨ &#x1f388;&#x1f388;作者主页&#xff1a; 喔的嘛呀&#x1f388;&#x1f388; 目录 引言 1. 缓存雪崩 1.1 问题描述 1.2 解决方案 1.2.1 加锁防止并发重建缓存 2. 缓存穿透 2.1 问题描述 2.2 解决方案 2.2.1 …

Ubuntu下安装Scala

前言 弄了一下终于成功装上了&#xff0c;这里对此进行一下总结 安装虚拟机 VMware虚拟机安装Ubuntu&#xff08;超详细图文教程&#xff09;_vmware安装ubuntu-CSDN博客https://blog.csdn.net/qq_43374681/article/details/129248167Download Ubuntu Desktop | Download | …

FinalShell连接Linux

远程连接linux 我们使用VMware可以得到Linux虚拟机&#xff0c;但是在/Mware中操作Linux的命令行页面不太方便&#xff0c;主要是: 内容的复制、粘贴跨越VMware不方便 文件的上传、下载跨越VMware不方便 不方便也就是和Linux系统的各类交互&#xff0c;跨越VMwar 到Linux操作系…

win11 更多网络适配器选项

win11更多网络适配器选项查找路径&#xff1a;控制面板→网络和共享中心→更改适配器设置

计算机二级Python刷题笔记------基本操作题23、33、35、37(考察字符串)

文章目录 第二十三题&#xff08;字符串替换&#xff1a;replace(old,new)&#xff09;第三十三题&#xff08;字符串遍历&#xff09;第三十五题&#xff08;字符串与列表&#xff09;第三十七题&#xff08;拼接字符串&#xff09; 第二十三题&#xff08;字符串替换&#xf…

Ubuntu进入python时报错:找不到命令 “python”,“python3” 命令来自 Debian 软件包 python3

一、错误描述 二、解决办法 进入”/usr/bin”目录下&#xff0c;查看/usr/bin目录中所有与python相关的文件和链接&#xff1a; cd /usr/bin ls -l | grep python 可以看到Python3指向的是Python3.10&#xff0c;而并无指向python3的软连接 只需要在python与python3之间手动…

2024.03.02蓝桥云课笔记

1.scanf与printf取消分隔符的限制方法 示例代码&#xff1a; int main() { char s[10];scanf("%d[^\n]",s);printf("%s",s);return 0; } 运行&#xff1a; 输入&#xff1a;Hello World 输出&#xff1a;Hello World 注&#xff1a;其中[]中是一个正则…

YTM32的同步串行通信外设SPI外设详解(Master Part)

YTM32的同步串行通信外设SPI外设详解&#xff08;Master Part&#xff09; 文章目录 YTM32的同步串行通信外设SPI外设详解&#xff08;Master Part&#xff09;IntroductionFeatures引脚信号时钟源其它不常用功能 Pricinple & Mechinism基于FIFO的命令和数据管理机制锁定配…

19. 学习人工智能如何从阅读论文中获取一手信息,并推荐一些技术论文

本文为 「茶桁的 AI 秘籍 - BI 篇 第 19 篇」 文章目录 Hi&#xff0c;你好。我是茶桁。 上节课给大家预告了&#xff0c;今天这节课咱们来看一篇论文。我们之前几节课中讲解的内容其实是在一些论文里面有使用到的。 我们先看一下论文的内容&#xff0c;讲讲 ALS。 就像我上节…

unsubscribe:Angular 项目中常见场景以及是否需要 unsubscribe

本文由庄汇晔同学编写~ 在 Angular 项目中&#xff0c;经常会使用到 observable subscribe&#xff0c;但是 subscribe 读取了数据之后&#xff0c;真的就是万事大吉了吗&#xff1f;这个问题的答案或许是&#xff0c;或许不是。有些 observable 需要 unsubscribe&#xff0c;…

【研发日记】Matlab/Simulink技能解锁(四)——在Simulink Debugger窗口调试

前言 见《【研发日记】Matlab/Simulink技能解锁(一)——在Simulink编辑窗口Debug》 见《【研发日记】Matlab/Simulink技能解锁(二)——在Function编辑窗口Debug》 见《【研发日记】Matlab/Simulink技能解锁(三)——在Stateflow编辑窗口Debug》 Block断点 前文在Simulink编辑窗口…

嵌入式Linux中GPIO设置的一些基本指令和步骤

一、GPIO的介绍 嵌入式Linux中的GPIO&#xff08;General Purpose Input/Output&#xff0c;通用输入/输出&#xff09;是一种常用的接口&#xff0c;允许开发者直接控制硬件设备的某些引脚&#xff0c;进行诸如LED控制、传感器读取、设备状态监测等任务。 二、设置步骤和示例…

雷电将军部分技能AOE范围测试

简单说一下&#xff0c;以往的AOE范围数据大部分来自Dim提供的拆包文件或泄露的GM端控制台显示的距离数据&#xff0c;如《AOE范围学》中的数据&#xff0c;然而米哈游自1.6版本及以后未再公开泄露过GM端&#xff0c;因为一些原因Dim也没再更新拆包文件中角色技能参数相关的部分…

C2_W2_Assignment_吴恩达_中英_Pytorch

Neural Networks for Handwritten Digit Recognition, Multiclass In this exercise, you will use a neural network to recognize the hand-written digits 0-9. 在本次练习中&#xff0c;您将使用神经网络来识别0-9的手写数字。 Outline 1 - Packages 2 - ReLU Activatio…

服务器有几种http强制跳转https设置方法

目前为站点安装SSL证书开启https加密访问已经是件很简单的事了&#xff0c;主要是免费SSL证书的普及&#xff0c;为大家提供了很好的基础。 Apache环境下如何http强制跳转https访问。Nginx环境下一般是通过修改“你的域名.conf”文件来实现的。 而Apache环境下通过修改.htacces…

类与对象(一)

目录 1 什么是面向过程和面向对象 1.1举例 2类的引入 3类的定义 3.1类的两种定义方式&#xff1a; 4.类的访问限定符及封装 4.1访问限定符 4.1.1为什么要有访问限定符 4.1.2有哪些访问限定符呢&#xff1f; 4.1.3简单举例理解 4.1.4C中的class与struct的区别(面试问题…

Tomcat基础及与Nginx实现动静分离,搭建高效稳定的个人博客系统

目录 引言 一、TOMCAT基础功能 &#xff08;一&#xff09;自动解压war包 &#xff08;二&#xff09;状态页 1.登录状态页 2.远程登录 &#xff08;三&#xff09;服务管理界面 &#xff08;四&#xff09;Host虚拟主机 1.设置虚拟主机 2.建立站点目录与文件 二、实…

python 使用curl_cffi 绕过jax3指纹-Cloudflare 5s盾

现在越来越多的网站已经能够通过JA3或者其他指纹信息&#xff0c;来识别你是不是爬虫了。传统的方式比如换UA&#xff0c;加代理是没有任何意义了&#xff0c;所以这个时候我们就需要使用到curl_cffi 了。 1.TLS 指纹是啥&#xff1f; 在绝大多数的网站都已经使用了 HTTPS&am…
最新文章