中小学教师课程排课系统 毕业设计 JAVA+Vue+SpringBoot+MySQL(二)

本文涉及的产品
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介: 中小学教师课程排课系统 毕业设计 JAVA+Vue+SpringBoot+MySQL


五、核心代码

5.1 查询课程

@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询课程")
public Result<IPage<Curriculum>> getByPage(@ModelAttribute Curriculum curriculum ,@ModelAttribute PageVo page){
    QueryWrapper<Curriculum> qw = new QueryWrapper<>();
    if(!ZwzNullUtils.isNull(curriculum.getTitle())) {
        qw.like("title",curriculum.getTitle());
    }
    if(!ZwzNullUtils.isNull(curriculum.getStatus())) {
        qw.like("status",curriculum.getStatus());
    }
    IPage<Curriculum> data = iCurriculumService.page(PageUtil.initMpPage(page),qw);
    return new ResultUtil<IPage<Curriculum>>().setData(data);
}

5.2 新增课程

@RequestMapping(value = "/insert", method = RequestMethod.POST)
@ApiOperation(value = "新增课程")
public Result<Curriculum> insert(Curriculum curriculum){
    iCurriculumService.saveOrUpdate(curriculum);
    return new ResultUtil<Curriculum>().setData(curriculum);
}

5.3 查询全部排课

@RequestMapping(value = "/getCardList", method = RequestMethod.GET)
@ApiOperation(value = "查询全部排课")
public Result<List<TeachingScheduleVo>> getCardList(){
    List<TeachingScheduleVo> ans = new ArrayList<>();
    QueryWrapper<TeachingSchedule> qw1 = new QueryWrapper<>();
    qw1.eq("x",1);
    qw1.orderByAsc("y");
    ans.add(new TeachingScheduleVo(1,iTeachingScheduleService.list(qw1)));
    QueryWrapper<TeachingSchedule> qw2 = new QueryWrapper<>();
    qw2.eq("x",2);
    qw2.orderByAsc("y");
    ans.add(new TeachingScheduleVo(2,iTeachingScheduleService.list(qw2)));
    QueryWrapper<TeachingSchedule> qw3 = new QueryWrapper<>();
    qw3.eq("x",3);
    qw3.orderByAsc("y");
    ans.add(new TeachingScheduleVo(3,iTeachingScheduleService.list(qw3)));
    QueryWrapper<TeachingSchedule> qw4 = new QueryWrapper<>();
    qw4.eq("x",4);
    qw4.orderByAsc("y");
    ans.add(new TeachingScheduleVo(4,iTeachingScheduleService.list(qw4)));
    QueryWrapper<TeachingSchedule> qw5 = new QueryWrapper<>();
    qw5.eq("x",5);
    qw5.orderByAsc("y");
    ans.add(new TeachingScheduleVo(5,iTeachingScheduleService.list(qw5)));
    QueryWrapper<TeachingSchedule> qw6 = new QueryWrapper<>();
    qw6.eq("x",6);
    qw6.orderByAsc("y");
    ans.add(new TeachingScheduleVo(6,iTeachingScheduleService.list(qw6)));
    QueryWrapper<TeachingSchedule> qw7 = new QueryWrapper<>();
    qw7.eq("x",7);
    qw7.orderByAsc("y");
    ans.add(new TeachingScheduleVo(7,iTeachingScheduleService.list(qw7)));
    return new ResultUtil<List<TeachingScheduleVo>>().setData(ans);
}

5.4 查询排课申请

@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询排课申请")
public Result<IPage<TeachingApply>> getByPage(@ModelAttribute TeachingApply teachingApply ,@ModelAttribute PageVo page){
    QueryWrapper<TeachingApply> qw = new QueryWrapper<>();
    User currUser = securityUtil.getCurrUser();
    QueryWrapper<User> userQw = new QueryWrapper<>();
    userQw.eq("id",currUser.getId());
    userQw.inSql("id","SELECT user_id FROM a_user_role WHERE del_flag = 0 AND role_id = '496138616573952'");
    if(iUserService.count(userQw) < 1L) {
        qw.eq("user_id",currUser.getId());
    }
    if(!ZwzNullUtils.isNull(teachingApply.getUserName())) {
        qw.like("user_name",teachingApply.getUserName());
    }
    if(!ZwzNullUtils.isNull(teachingApply.getCurriculumName())) {
        qw.like("curriculum_name",teachingApply.getCurriculumName());
    }
    if(!ZwzNullUtils.isNull(teachingApply.getScheduleName())) {
        qw.like("schedule_name",teachingApply.getScheduleName());
    }
    IPage<TeachingApply> data = iTeachingApplyService.page(PageUtil.initMpPage(page),qw);
    return new ResultUtil<IPage<TeachingApply>>().setData(data);
}

5.5 自动排课算法

@RequestMapping(value = "/work", method = RequestMethod.GET)
@ApiOperation(value = "自动排课")
public Result<Object> work(){
    List<TeachingApply> applyList = iTeachingApplyService.list();
    List<TeachingApplyVo> ans = new ArrayList<>();
    // 分离用户的排课申请
    for (TeachingApply a : applyList) {
        boolean flag = true;
        for (TeachingApplyVo vo : ans) {
            if(Objects.equals(a.getUserId(),vo.getUserId())) {
                vo.getList().add(a);
                flag = false;
                break;
            }
        }
        if(flag) {
            TeachingApplyVo vo = new TeachingApplyVo();
            vo.setUserId(a.getUserId());
            vo.setUserName(a.getUserName());
            List<TeachingApply> aList = new ArrayList<>();
            aList.add(a);
            vo.setList(aList);
            vo.setFlag(0);
            ans.add(vo);
        }
    }
    // 课位初始化
    List<TeachingSchedule> scheduleList = iTeachingScheduleService.list();
    for (TeachingSchedule s : scheduleList) {
        s.setCurId("");
        s.setCurName("");
        s.setTeacherName("");
    }
    // 根据排课申请数量升序排列,尽可能满足多的教师完成排课
    Collections.sort(ans, new Comparator<TeachingApplyVo>() {
        @Override
        public int compare(TeachingApplyVo o1, TeachingApplyVo o2) {
            return o1.getList().size() - o2.getList().size();
        }
    });
    for(int i = 0; i < ans.size(); i ++) {
        List<TeachingSchedule> tempList = new ArrayList<>();
        for (TeachingSchedule s : scheduleList) {
            tempList.add(s);
        }
        // 判断能否满足排课
        boolean flagSum = true;
        for (TeachingApply a : ans.get(i).getList()) {
            boolean flag = true;
            for (TeachingSchedule teachingSchedule : tempList) {
                if(Objects.equals(a.getScheduleId(),teachingSchedule.getId()) && ZwzNullUtils.isNull(teachingSchedule.getCurId())) {
                    // 排课成功
                    teachingSchedule.setCurId(a.getCurriculumId());
                    teachingSchedule.setCurName(a.getCurriculumName());
                    teachingSchedule.setTeacherName(a.getUserName());
                    a.setStatus("排课成功");
                    flag = false;
                    break;
                }
            }
            if(flag) {
                // 排课失败,下一位
                flagSum = false;
                break;
            }
        }
        if(flagSum) {
            // 如果全部课程可以排课,则保存
            scheduleList = new ArrayList<>();
            for (TeachingSchedule vo : tempList) {
                scheduleList.add(vo);
            }
            ans.get(i).setFlag(1);
        } else {
            // 否则不保存
        }
    }
    // 未完成排课的,按顺序能排上的排上
    for (TeachingApplyVo vo : ans) {
        if(Objects.equals(1,vo.getFlag())) {
            continue;
        }
        for (TeachingApply a : vo.getList()) {
            for (TeachingSchedule teachingSchedule : scheduleList) {
                if(Objects.equals(a.getScheduleId(),teachingSchedule.getId()) && ZwzNullUtils.isNull(teachingSchedule.getCurId())) {
                    // 补排课成功
                    teachingSchedule.setCurId(a.getCurriculumId());
                    teachingSchedule.setCurName(a.getCurriculumName());
                    teachingSchedule.setTeacherName(a.getUserName());
                    a.setStatus("排课成功");
                    break;
                }
            }
        }
    }
    // 保存排课数据
    for (TeachingSchedule teachingSchedule : scheduleList) {
        iTeachingScheduleService.saveOrUpdate(teachingSchedule);
    }
    // 保存申请数据
    for (TeachingApplyVo vo : ans) {
        for (TeachingApply a : vo.getList()) {
            if(!Objects.equals("排课成功",a.getStatus())) {
                a.setStatus("排课失败");
            }
            iTeachingApplyService.saveOrUpdate(a);
        }
    }
    return ResultUtil.success();
}

六、免责说明

  • 本项目仅供个人学习使用,商用授权请联系博主,否则后果自负。
  • 博主拥有本软件构建后的应用系统全部内容所有权及独立的知识产权,拥有最终解释权。
  • 如有问题,欢迎在仓库 Issue 留言,看到后会第一时间回复,相关意见会酌情考虑,但没有一定被采纳的承诺或保证。

下载本系统代码或使用本系统的用户,必须同意以下内容,否则请勿下载!

  1. 出于自愿而使用/开发本软件,了解使用本软件的风险,且同意自己承担使用本软件的风险。
  2. 利用本软件构建的网站的任何信息内容以及导致的任何版权纠纷和法律争议及后果和博主无关,博主对此不承担任何责任。
  3. 在任何情况下,对于因使用或无法使用本软件而导致的任何难以合理预估的损失(包括但不仅限于商业利润损失、业务中断与业务信息丢失),博主概不承担任何责任。
  4. 必须了解使用本软件的风险,博主不承诺提供一对一的技术支持、使用担保,也不承担任何因本软件而产生的难以预料的问题的相关责任。
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
4月前
|
移动开发 监控 小程序
java家政平台源码,家政上门清洁系统源码,数据多端互通,可直接搭建使用
一款基于Java+SpringBoot+Vue+UniApp开发的家政上门系统,支持小程序、APP、H5、公众号多端互通。涵盖用户端、技工端与管理后台,支持多城市、服务分类、在线预约、微信支付、抢单派单、技能认证、钱包提现等功能,源码开源,可直接部署使用。
373 24
|
4月前
|
设计模式 消息中间件 传感器
Java 设计模式之观察者模式:构建松耦合的事件响应系统
观察者模式是Java中常用的行为型设计模式,用于构建松耦合的事件响应系统。当一个对象状态改变时,所有依赖它的观察者将自动收到通知并更新。该模式通过抽象耦合实现发布-订阅机制,广泛应用于GUI事件处理、消息通知、数据监控等场景,具有良好的可扩展性和维护性。
445 8
|
4月前
|
安全 前端开发 Java
使用Java编写UDP协议的简易群聊系统
通过这个基础框架,你可以进一步增加更多的功能,例如用户认证、消息格式化、更复杂的客户端界面等,来丰富你的群聊系统。
231 11
|
4月前
|
JavaScript Java 关系型数据库
基于springboot的项目管理系统
本文探讨项目管理系统在现代企业中的应用与实现,分析其研究背景、意义及现状,阐述基于SSM、Java、MySQL和Vue等技术构建系统的关键方法,展现其在提升管理效率、协同水平与风险管控方面的价值。
|
4月前
|
搜索推荐 JavaScript Java
基于springboot的儿童家长教育能力提升学习系统
本系统聚焦儿童家长教育能力提升,针对家庭教育中理念混乱、时间不足、个性化服务缺失等问题,构建科学、系统、个性化的在线学习平台。融合Spring Boot、Vue等先进技术,整合优质教育资源,提供高效便捷的学习路径,助力家长掌握科学育儿方法,促进儿童全面健康发展,推动家庭和谐与社会进步。
|
4月前
|
JavaScript Java 关系型数据库
基于springboot的古树名木保护管理系统
本研究针对古树保护面临的严峻挑战,构建基于Java、Vue、MySQL与Spring Boot技术的信息化管理系统,实现古树资源的动态监测、数据管理与科学保护,推动生态、文化与经济可持续发展。
|
4月前
|
监控 安全 JavaScript
2025基于springboot的校车预定全流程管理系统
针对传统校车管理效率低、信息不透明等问题,本研究设计并实现了一套校车预定全流程管理系统。系统采用Spring Boot、Java、Vue和MySQL等技术,实现校车信息管理、在线预定、实时监控等功能,提升学校管理效率,保障学生出行安全,推动教育信息化发展。
|
4月前
|
人工智能 Java 关系型数据库
基于springboot的画品交流系统
本项目构建基于Java+Vue+SpringBoot+MySQL的画品交流系统,旨在解决传统艺术交易信息不透明、流通受限等问题,融合区块链与AI技术,实现画品展示、交易、鉴赏与社交一体化,推动艺术数字化转型与文化传播。
|
4月前
|
JavaScript Java 关系型数据库
基于springboot的高校运动会系统
本系统基于Spring Boot、Vue与MySQL,实现高校运动会报名、赛程安排及成绩管理的全流程信息化,提升组织效率,杜绝信息错漏与冒名顶替,推动体育赛事智能化发展。