多模块项目使用springboot框架进行业务处理

项目目录

1、在Result定义返回结果

package com.edu.result;

import lombok.Data;

import java.io.Serializable;

/**
 * 后端统一返回结果
 * @param <T>
 */
@Data
public class Result<T> implements Serializable {

    private Integer code; //编码:1成功,0和其它数字为失败
    private String msg; //错误信息
    private T data; //数据

    public static <T> Result<T> success() {
        Result<T> result = new Result<T>();
        result.code = 1;
        return result;
    }

    public static <T> Result<T> success(T object) {
        Result<T> result = new Result<T>();
        result.data = object;
        result.code = 1;
        return result;
    }

    public static <T> Result<T> error(String msg) {
        Result result = new Result();
        result.msg = msg;
        result.code = 0;
        return result;
    }

}

2、写实体类(entity,和表中的属性一一对应) 

package com.edu.entity;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

@Data
@AllArgsConstructor
@NoArgsConstructor
public class Class {
    private String classId;
    private int classSize;
    private String headTeacher;
    private int attendanceTimes;
    private int focus;
}

3、在(vo)中定义类,写自己想要返回的属性

package com.edu.vo;

import io.swagger.models.auth.In;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

@Data
@AllArgsConstructor
@NoArgsConstructor
public class AbsentStuVo {
    private String personName;
    private String studentId;
    private String classId;
    private Integer attendanceStatus;
    private String headTeacher;
    private String attendRate;
}

3、书写mapper层

package com.edu.mapper;

import com.edu.vo.*;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;

import java.util.List;


@Mapper
public interface StudentMapper {
    /**
     * 根据学生id显示请假列表
     * @param studentId
     * @return
     */

    @Select("select start_time, end_time, reason, leave_status, submit_time from leave_applications where student_id=#{studentId}")
    List<LeaveApplicationsVo> listLeaveApplications(String studentId);

    /**
     * 根据学生id显示迟到列表
     * @param studentId
     * @return
     */

    @Select("select  l.late_date,c.course_session,c.course_name , l.teacher,l.entry_time,l.late_duration from late_attendance l left join course c on c.course_id=l.course_id where l.student_id=#{studentId}")
    List<LateAttendanceVo> listLateAttendance(String studentId);

    /**
     *根据学生id显示旷课列表
     * @param studentId
     * @return
     */
    @Select("select  a.absence_date,a.class_period,u.course_name,a.teacher from absence_record a left join course u on u.course_id=a.course_id where a.student_id=#{studentId}")
    List<AbsenceRecordVo> listAbsenceRecord(String studentId);

    /**
     * 请假列表详情
     * @param studentId
     * @return
     */
    @Select("select l.student_id, s.student_name, l.start_time,l.end_time,l.reason,l.leave_status from leave_applications l left join student s on l.student_id=s.student_id where l.student_id=#{studentId}")
    List<LeaveApplicationsdetailVo> LeaveApplicationsdetail(String studentId);


    /**
     * 根据学生id查询该学生各科的缺勤次数
     * @param studentId
     * @return
     */
    @Select("SELECT c.course_name, IFNULL(COUNT( DISTINCT a.absent_id), 0) AS absence_count FROM course c LEFT JOIN absent_students a ON c.course_id = a.course_id AND a.student_id = #{studentId} GROUP BY c.course_name")
    List<CourseAbsenceCountVo> viewAbsenceCountsForSubjects(String studentId);

    /**
     * 根据学生id查询学生信息
     * @param studentId
     * @return
     */
    @Select("SELECT s.student_id, s.student_name, c.class_name, c.head_teacher," +
            " (pa.attendance_count /(pa.attendance_count + pa.leave_count+pa.absent_count)) * 100 AS attendance_rate  " +
            "FROM  student s JOIN  class c ON s.class_id = c.class_id  JOIN personal_attendance pa ON s.student_id = pa.student_id " +
            "WHERE s.student_id = #{studentId}")

    List<StudentDetailVO> viewStudentDetail(String studentId);

    /**
     * 申请请假
     * @param studentId 学生id
     * @param startTime 开始时间
     * @param endTime 结束时间
     * @param reason 原因
     * @return
     */
    @Insert("INSERT INTO leave_applications (student_id, start_time, end_time, reason, submit_time)" +
            "VALUES (#{studentId}, #{startTime}, #{endTime}, #{reason}, NOW())")
    Integer insertLeaveRequest(String studentId, String startTime, String endTime, String reason);
}

4、编写service层

package com.edu.service;

import com.edu.result.Result;
import com.edu.vo.*;

import java.util.List;

public interface StudentService {
    /**
     * 根据学生id显示请假列表
     * @param studentId
     * @return
     */
    List<LeaveApplicationsVo> listLeaveApplications(String studentId);

    /**
     * 根据学生id显示迟到列表
     * @param studentId
     * @return
     */
    List<LateAttendanceVo> listLateAttendance(String studentId);

    /**
     * 根据学生id显示旷课列表
     * @param studentId
     * @return
     */
    List<AbsenceRecordVo> listAbsenceRecord(String studentId);

    /**
     * 请假列表详情
     * @param studentId
     * @return
     */
    List<LeaveApplicationsdetailVo> LeaveApplicationsdetail(String studentId);

    /**
     * 根据学生id查询该学生各科的缺勤次数
     * @param studentId
     * @return
     */
    List<CourseAbsenceCountVo> viewAbsenceCountsForSubjects(String studentId);

    /**
     * 根据学生id查询学生信息
     * @param studentId
     * @return
     */
    List<StudentDetailVO> viewStudentDetail(String studentId);

    /**
     * 申请请假
     * @param studentId 学生id
     * @param startTime 开始时间
     * @param endTime 结束时间
     * @param reason 原因
     * @return
     */
    Result insertLeaveRequest(String studentId, String startTime, String endTime, String reason);

}

5、编写service层逻辑

package com.edu.service.Impl;

import com.edu.mapper.StudentMapper;
import com.edu.result.Result;
import com.edu.service.StudentService;
import com.edu.vo.*;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.List;

@Service
@Slf4j
public class StudentServiceImpl implements StudentService {
    @Autowired
    private StudentMapper studentMapper;

    /**
     * 根据学生id显示请假列表
     * @param studentId
     * @return
     */
    @Override
    public List<LeaveApplicationsVo> listLeaveApplications(String studentId){

        return studentMapper.listLeaveApplications(studentId);
    }

    /**
     * 根据学生id显示迟到列表
     * @param studentId
     * @return
     */
    @Override
    public  List<LateAttendanceVo> listLateAttendance(String studentId){

        return studentMapper.listLateAttendance(studentId);
    }

    /**
     * 根据学生id显示旷课列表
     * @param studentId
     * @return
     */
    @Override
    public  List<AbsenceRecordVo> listAbsenceRecord(String studentId){

        return studentMapper.listAbsenceRecord(studentId);
    }

    /**
     * 请假列表详情
     * @param studentId
     * @return
     */
    @Override
    public List<LeaveApplicationsdetailVo> LeaveApplicationsdetail(String studentId){
        return studentMapper.LeaveApplicationsdetail(studentId);
    }

    /**
     * 根据学生id查询该学生各科的缺勤次数
     * @param studentId
     * @return
     */
    @Override
    public List<CourseAbsenceCountVo> viewAbsenceCountsForSubjects(String studentId){
        return studentMapper.viewAbsenceCountsForSubjects(studentId);
    }

    /**
     * 根据学生id查询学生信息
     * @param studentId
     * @return
     */
    @Override
    public  List<StudentDetailVO> viewStudentDetail(String studentId){
        return studentMapper.viewStudentDetail(studentId);
    }

    /**
     * 申请请假
     * @param studentId 学生id
     * @param startTime 开始时间
     * @param endTime 结束时间
     * @param reason 原因
     * @return
     */
    @Override
    public Result insertLeaveRequest(String studentId, String startTime, String endTime, String reason){
        try {

            int deletedCount = studentMapper.insertLeaveRequest(studentId,startTime,endTime,reason);
            if (deletedCount == 0) {
                return Result.error("插入失败");
            } else {
                return Result.success("插入成功");
            }
        } catch (Exception e) {
            // 记录异常或进行其他处理
            return Result.error("插入时发生错误:" + e.getMessage());
        }
    }


}

6、编写控制层(controller)

package com.edu.controller;

import com.edu.result.Result;
import com.edu.service.StudentService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping("/attendance/student")
@Slf4j
public class StudentController {
    @Autowired
    private StudentService studentService;

    /**
     * 根据学生id显示请假列表
     * @param studentId
     * @return
     */
    @GetMapping("/listLeaveApplications")
    public Result listLeaveApplications(String studentId)  {
        return Result.success(studentService.listLeaveApplications(studentId));
    }

    /**
     * 根据学生id显示迟到列表
     * @param studentId
     * @return
     */
    @GetMapping("/listLateAttendance")
    public Result listLateAttendance(String studentId)  {
        return Result.success(studentService.listLateAttendance(studentId));
    }

    /**
     * 根据学生id显示旷课列表
     * @param studentId
     * @return
     */
    @GetMapping("/listAbsenceRecord")
    public Result listAbsenceRecord(String studentId)  {
        return Result.success(studentService.listAbsenceRecord(studentId));
    }

    /**
     * 请假列表详情
     * @param studentId
     * @return
     */
    @GetMapping("/viewLeaveApplications")
    public Result LeaveApplicationsdetail(String studentId)  {
        return Result.success(studentService.LeaveApplicationsdetail(studentId));
    }

    /**
     * 根据学生id查询该学生各科的缺勤次数
     * @param studentId
     * @return
     */
    @GetMapping("/viewAbsenceCountsForSubjects")
    public Result viewAbsenceCountsForSubjects(String studentId)  {
        return Result.success(studentService.viewAbsenceCountsForSubjects(studentId));
    }

    /**
     * 根据学生id查询学生信息
     * @param studentId
     * @return
     */
    @GetMapping("/viewStudentDetail")
    public Result viewStudentDetail(String studentId)  {
        return Result.success(studentService.viewStudentDetail(studentId));
    }

    /**
     * 申请请假
     * @param studentId 学生id
     * @param startTime 开始时间
     * @param endTime 结束时间
     * @param reason 原因
     * @return
     */
    @PostMapping("/insertLeaveRequest")
    public Result insertLeaveRequest(String studentId, String startTime, String endTime, String reason)  {
        return Result.success(studentService.insertLeaveRequest(studentId,startTime,endTime,reason));
    }

}

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

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

相关文章

【U8+】用友固定资产卡片拆分提示:未设置对象变量或With block变量。

【问题描述】 用友U8软件中&#xff0c; 操作固定资产模块&#xff0c;针对所有资产进行卡片拆分的时候&#xff0c; 提示&#xff1a;未设置对象变量或With block变量。 确定后仍然能打开卡片拆分界面&#xff0c;但是界面显示异常看不到拆分明细信息&#xff0c;并且保存后拆…

LeetCode-Java:303、304区域检索(前缀和)

文章目录 题目303、区域和检索&#xff08;数组不可变&#xff09;304、二维区域和检索&#xff08;矩阵不可变&#xff09; 解①303&#xff0c;一维前缀和②304&#xff0c;二维前缀和 算法前缀和一维前缀和二维前缀和 题目 303、区域和检索&#xff08;数组不可变&#xff…

一些 VLP 下游任务的相关探索

一、Image-Text Retrieval (ITR , 图像文本检索) 任务目的&#xff1a; 检索与给定文本最匹配的图像&#xff0c;或者给定图像最匹配的文本。 跨模态图像-文本检索&#xff08;ITR&#xff09;是根据用户给定的一种模态中的表达&#xff0c;从另一模态中检索出相关样本&#x…

工厂方法模式:解锁灵活的对象创建策略

在软件设计中&#xff0c;工厂方法模式是一种非常实用的创建型设计模式&#xff0c;它不仅提升了系统的灵活性&#xff0c;还简化了对象的创建过程。本文将详细探讨工厂方法模式的核心概念、实现方式、应用场景以及与其他设计模式的对比&#xff0c;旨在提供一份全面且实用的指…

flutter中鼠标检测事件的应用---主要在于网页端使用

flutter中鼠标检测事件的应用—主要在于网页端使用 鼠标放上去 主要代码 import package:flutter/material.dart;class CustomStack extends StatefulWidget {override_CustomStack createState() > _CustomStack(); }class _CustomStack extends State<CustomStack>…

MySQL——创建和插入

一、插入数据 INSERT 使用建议; 在任何情况下建议列出列名&#xff0c;在 VALUES 中插入值时&#xff0c;注意值和列的意义对应关系 values 指定的值顺序非常重要&#xff0c;决定了值是否被保存到正确的列中 在指定了列名的情况下&#xff0c;你可以仅对需要插入的列给到…

C++——StackQueue

目录 一Stack 1介绍 2接口 3模拟实现 4栈的oj题 二Queue 1介绍 2接口 3模拟实现 三容器适配器 1再谈栈和队列 四优先级队列 1接口 ​编辑 2仿函数 五dequeue的简单介绍 一Stack 1介绍 先来看看库中对栈的介绍&#xff1a; 1. stack是一种容器适配器&#x…

自养号测评技术:如何快速提高亚马逊、速卖通、沃尔玛新号的权重?

亚马逊平台高度关注买家账号权重&#xff0c;对于希望快速提升listing曝光与销量的卖家而言&#xff0c;拥有高权重买家账号进行下单至关重要。前提是&#xff0c;确保您的listing已经过精细优化。当前&#xff0c;市场上存在众多自养号服务商&#xff0c;然而由于多种原因&…

外汇兑换问题的最优子结构分析

外汇兑换问题的最优子结构分析 一、 当所有交易佣金为零时1.1 伪代码示例&#xff1a;1.2 C代码示例 二、 佣金不为零时的最优子结构性质三、 结论 在考虑外汇兑换问题时&#xff0c;我们面临的是如何通过一系列兑换操作&#xff0c;以最小的成本将一种货币转换为另一种货币。这…

网络变压器(网络隔离变压器)是如何影响网通设备的传输速率的呢?

Hqst华轩盛(石门盈盛)电子导读&#xff1a;今天介绍网络变压器&#xff08;网络隔离变压器/网络滤波器&#xff09;是如何影响网通设备的传输速率的 一、网络变压器&#xff08;网络隔离变压器/网络滤波器&#xff09;的工作原理 网络变压器&#xff08;网络隔离变压器/网络滤…

Docker 学习笔记(六):挑战容器数据卷技术一文通,实战多个 MySQL 数据同步,能懂会用,初学必备

一、前言 记录时间 [2024-4-11] 系列文章简摘&#xff1a; Docker学习笔记&#xff08;二&#xff09;&#xff1a;在Linux中部署Docker&#xff08;Centos7下安装docker、环境配置&#xff0c;以及镜像简单使用&#xff09; Docker 学习笔记&#xff08;三&#xff09;&#x…

arm-linux-gnueabihf-gcc默认目录

默认编译的头文件目录&#xff1a; /usr/local/arm/gcc-linaro-4.9.4-2017.01-x86_64_arm-linux-gnueabihf/arm-linux-gnueabihf/lib 默认编译的库文件目录&#xff1a; /usr/local/arm/gcc-linaro-4.9.4-2017.01-x86_64_arm-linux-gnueabihf/arm-linux-gnueabihf/include/ …

校招生如何准备软件测试、测试开发岗位的面试?

校招生如何准备软件测试、测试开发岗位的面试&#xff1f; 求职建议 大家都很困惑如何学习测试&#xff1f;如何准备测试方面的面试&#xff1f; 我有朋友是做研发的&#xff0c;他认为测试不用准备&#xff0c;直接用开发的简历就行。也有人认为要学习一些测试理论&#xf…

使用 create-vue 脚手架工具创建一个基于 Vite 的项目,并包含加入 Vue Router 等可选项

如果你打算启动一个新项目&#xff0c;你可能会发现使用 create-vue 这个脚手架工具更容易&#xff0c;它能创建一个基于 Vite 的项目&#xff0c;并包含加入 Vue Router 的选项&#xff0c;指令如下&#xff1a; // npm npm create vuelatest// yarn yarn create vue// pnpm …

HTML、CSS --javaweb学习笔记

记录一些重要的知识点 CSS引入方式 行内样式&#xff1a;<h1 style"...">内嵌样式&#xff1a;<style>…</style>外联样式&#xff1a;xxx.css <link href"..."> 颜色表示 关键字&#xff1a;red、green.......rgb表示法&…

java快速构建飞书API消息推送、消息加急等功能

文章目录 飞书机器人自定义机器人自定义应用机器人 自定义应用发送消息普通文本 text富文本 post图片 image文件 file语音 audio视频 media消息卡片 interactive分享群名片 share_chat分享个人名片 share_user 批量发送消息消息加急发送应用内加急发送短信加急 发送电话加急spr…

【随身wifi京东金榜排名】格行vs华为vs上赞随身wifi哪款最好用?格行随身wifi官方正品,格行随身wifi怎么样?

第一名&#xff1a;格行随身wifi 综合分99.1 随身WiFi行业领跑品牌 &#xff0c;15年行业经验 &#xff0c;随身WiFi口碑榜第一名。轻便小巧&#xff0c;支持三网通&#xff0c;可以随时随地提供稳定高速的网络连接。使用目前先进的马维尔芯片&#xff0c;信号稳定&#xff0…

Unet++(pytorch实现)

Unet++网络 Dense connection Unet++继承了Unet的结构,同时又借鉴了DenseNet的稠密连接方式(图1中各种分支)。 作者通过各层之间的稠密连接,互相连接起来,就像Denset那样,前前后后每一个模块互相作用,每一个模块都能看到彼此,那对彼此互相熟悉,分割效果自然就会变好…

位像素海外仓管理系统对接ERP系统教程,一对一教学

在海外仓管理过程中&#xff0c;对接ERP系统的重要性不言而喻的。这种对接不仅能让数据实时共享&#xff0c;还能让海外仓管理者优化整个供应链管理流程。 因此&#xff0c;今天小编就来教大家&#xff0c;海外仓仓库系统是怎么对接ERP物流系统的&#xff1f; 1.分析需求 在对接…

2024年危险化学品经营单位安全管理人员证考试题库及试题解析

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 2024年危险化学品经营单位安全管理人员证考试题库及危险化学品经营单位安全管理人员试题解析是安全生产模拟考试一点通结合&#xff08;安监局&#xff09;特种作业人员操作证考试大纲和&#xff08;质检局&#xff0…