基于SpringBoot的考研专业课程管理系统 JAVA简易版

在这里插入图片描述


目录

  • 一、摘要
    • 1.1 项目介绍
    • 1.2 项目录屏
  • 二、功能模块
    • 2.1 数据中心模块
    • 2.2 考研高校模块
    • 2.3 高校教师管理模块
    • 2.4 考研专业模块
    • 2.5 考研政策模块
  • 三、系统设计
    • 3.1 用例设计
    • 3.2 数据库设计
      • 3.2.1 考研高校表
      • 3.2.2 高校教师表
      • 3.2.3 考研专业表
      • 3.2.4 考研政策表
  • 四、系统展示
  • 五、核心代码
    • 5.1 查询考研课程
    • 5.2 新增考研专业
    • 5.3 新增考研政策
    • 5.4 查询考研学校
    • 5.5 新增高校教师
  • 六、免责说明


一、摘要

1.1 项目介绍

基于JAVA+Vue+SpringBoot+MySQL 的考研专业课程管理系统,包含了考研课程、考研专业、考研注册、考研院校和高校教师模块,还包含系统自带的用户管理、部门管理、角色管理、菜单管理、日志管理、数据字典管理、文件管理、图表展示等基础模块,考研专业课程管理系统基于角色的访问控制,给学生、高校管理员使用,可将权限精确到按钮级别,您可以自定义角色并分配权限,系统适合设计精确的权限约束需求。

1.2 项目录屏


二、功能模块

为了能让开发出来的考研专业课程管理系统真正投入使用,所以需要对系统的需求加以分析设计,以下分别对功能性需求和可行性两方面分别对考研专业课程管理系统进行需求分析。

本文设计的考研专业课程管理系统的包括了系统数据中心模块,用来存放管理系统通用的模块,另外分别设计了考研高校模块、高校教师管理模块、考研专业模块、考研政策模块这四大模块,用于存放系统的核心业务逻辑。

在这里插入图片描述

2.1 数据中心模块

数据中心模块包含了对考研专业课程管理系统的基础模块,比如管理谁可以登录这套系统,记录这些人登录系统做了什么,不同的人拥有不同权限的管理。

2.2 考研高校模块

考研高校模块用于对考研高校的数据进行管理,其中包括高校名称、所属省份、介绍、办学性质、高校等级、师资力量、学科建设、学术科研等,可以通过此模块对考研高校数据进行添加、编辑更新、删除、查询操作。

2.3 高校教师管理模块

高校教师管理模块是对高校的教师信息进行管理,高校教师是高校教学的参与者,高校教师字段包括教师姓名、性别、教师介绍、联系电话、学历、毕业院校、所属高校、备注等,管理员可以新增高校教师的数据,学生可以查询管理员发布的高校教师信息。

2.4 考研专业模块

考研专业模块是为了管理各大高校开设的考研专业,有了考研高校后后,学生可以查询每个高校的考研专业,其中考研专业的字段包括专业名称、专业介绍、就业去向、所属高校ID、所属高校、创建人、创建时间、备注等,管理员可以增加、删除、编辑和条件查询考研专业,学生可以查询指定高校开设的考研专业。

2.5 考研政策模块

考研政策模块是维护关于考研的相关政策,如奖学金补助、考研政策图解等。考研政策模块是为了帮助考研学生备考,避免错过各类优待政策,其中考研政策包括政策名称、政策内容、适用群体、状态、排序值、发布日期、创建人、创建时间等,管理员可以增加、删除、编辑和条件查询考研政策内容,学生可以按需查询适配的考研政策。


三、系统设计

3.1 用例设计

UML是面向对象的图形化建模语言,具有表示容易,定义友好,适用范畴广泛,功能强大。用例图是用例模型的一种,需求分析人员可采用用例图表示用户操作行为。考研专业课程管理系统的用例图设计主要包括学生用户用例图设计、考研管理员用例设计。

在这里插入图片描述

3.2 数据库设计

3.2.1 考研高校表

在这里插入图片描述

3.2.2 高校教师表

在这里插入图片描述

3.2.3 考研专业表

在这里插入图片描述

3.2.4 考研政策表

在这里插入图片描述


四、系统展示

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


五、核心代码

5.1 查询考研课程

@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询考研课程")
public Result<IPage<PostgraduateCurriculum>> getByPage(@ModelAttribute PostgraduateCurriculum postgraduateCurriculum ,@ModelAttribute PageVo page){QueryWrapper<PostgraduateCurriculum> qw = new QueryWrapper<>();if(!ZwzNullUtils.isNull(postgraduateCurriculum.getTitle())) {qw.like("title",postgraduateCurriculum.getTitle());}if(!ZwzNullUtils.isNull(postgraduateCurriculum.getLevel())) {qw.eq("level",postgraduateCurriculum.getLevel());}if(!ZwzNullUtils.isNull(postgraduateCurriculum.getMajorId())) {qw.eq("major_id",postgraduateCurriculum.getMajorId());}IPage<PostgraduateCurriculum> data = iPostgraduateCurriculumService.page(PageUtil.initMpPage(page),qw);return new ResultUtil<IPage<PostgraduateCurriculum>>().setData(data);
}

5.2 新增考研专业

@RequestMapping(value = "/insert", method = RequestMethod.POST)
@ApiOperation(value = "新增考研专业")
public Result<PostgraduateMajor> insert(PostgraduateMajor postgraduateMajor){PostgraduateSchool school = iPostgraduateSchoolService.getById(postgraduateMajor.getSchoolId());if(school == null) {return ResultUtil.error("考研院校不存在");}postgraduateMajor.setSchoolName(school.getTitle());iPostgraduateMajorService.saveOrUpdate(postgraduateMajor);return new ResultUtil<PostgraduateMajor>().setData(postgraduateMajor);
}

5.3 新增考研政策

@RequestMapping(value = "/insert", method = RequestMethod.POST)
@ApiOperation(value = "新增考研政策")
public Result<PostgraduatePolicy> insert(PostgraduatePolicy postgraduatePolicy){if(Objects.equals(0,postgraduatePolicy.getSortOrder().compareTo(BigDecimal.ZERO))) {postgraduatePolicy.setSortOrder(BigDecimal.valueOf(iPostgraduatePolicyService.count() + 1L));}postgraduatePolicy.setReleaseDate(DateUtil.today());iPostgraduatePolicyService.saveOrUpdate(postgraduatePolicy);return new ResultUtil<PostgraduatePolicy>().setData(postgraduatePolicy);
}

5.4 查询考研学校

@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询考研学校")
public Result<IPage<PostgraduateSchool>> getByPage(@ModelAttribute PostgraduateSchool postgraduateSchool ,@ModelAttribute PageVo page){QueryWrapper<PostgraduateSchool> qw = new QueryWrapper<>();if(!ZwzNullUtils.isNull(postgraduateSchool.getTitle())) {qw.like("title",postgraduateSchool.getTitle());}if(!ZwzNullUtils.isNull(postgraduateSchool.getSchoolLevel())) {qw.eq("school_level",postgraduateSchool.getSchoolLevel());}if(!ZwzNullUtils.isNull(postgraduateSchool.getProvince())) {qw.eq("province",postgraduateSchool.getProvince());}IPage<PostgraduateSchool> data = iPostgraduateSchoolService.page(PageUtil.initMpPage(page),qw);return new ResultUtil<IPage<PostgraduateSchool>>().setData(data);
}

5.5 新增高校教师

@RequestMapping(value = "/insert", method = RequestMethod.POST)
@ApiOperation(value = "新增高校教师")
public Result<PostgraduateTeacher> insert(PostgraduateTeacher postgraduateTeacher){PostgraduateSchool school = iPostgraduateSchoolService.getById(postgraduateTeacher.getSchoolId());if(school == null) {return ResultUtil.error("高校不存在");}postgraduateTeacher.setSchoolName(school.getTitle());iPostgraduateTeacherService.saveOrUpdate(postgraduateTeacher);return new ResultUtil<PostgraduateTeacher>().setData(postgraduateTeacher);
}

六、免责说明

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

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

  1. 出于自愿而使用/开发本软件,了解使用本软件的风险,且同意自己承担使用本软件的风险。
  2. 利用本软件构建的网站的任何信息内容以及导致的任何版权纠纷和法律争议及后果和博主无关,博主对此不承担任何责任。
  3. 在任何情况下,对于因使用或无法使用本软件而导致的任何难以合理预估的损失(包括但不仅限于商业利润损失、业务中断与业务信息丢失),博主概不承担任何责任。
  4. 必须了解使用本软件的风险,博主不承诺提供一对一的技术支持、使用担保,也不承担任何因本软件而产生的难以预料的问题的相关责任。

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

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

相关文章

GPTs | Actions应用案例

上篇文章说道&#xff0c;如何使用创建的GPTs通过API接口去获取外部的一些信息&#xff0c;然后把获取的外部信息返回给ChatGPT让它加工出来&#xff0c;回答你的问题&#xff0c;今天我们就来做一个通俗易懂的小案例&#xff0c;让大家来初步了解一下它的使用法&#xff01; …

nodejs安装指导教程

1.nodejs下载 去官网下载对应的安装包即可 2.安装 下载的文件如果是exe文件直接安装&#xff0c;在弹出指导安装的界面有个addpath&#xff0c;可以将其勾选上&#xff0c;免得再去系统的环境变量中添加该属性。达成的效果就是&#xff0c;让npm命令到文件各个地方都可以被使…

MySQL基本操作 DDL DML DQL三大操作介绍

DDL 数据(结构)定义 创建表DML 数据操作 增删改DQL 查询语句 DDL 数据(结构)定义 创建表 创建 删除数据 注释 --空格内容 创建数据库 CREATE DATABASE [if not exists] 数据库名 [ CHARSET utf8]eg:CREATE DATABASE IF NOT EXISTS school CHARSET utf8如果对应school不存在,…

数字门牌管理系统:提升数据质量与服务品质的关键

一、引言 在当今社会&#xff0c;各行各业对数据质量的要求越来越高。为了满足客户需求并遵循国家行业标准&#xff0c;数字门牌管理系统应运而生。该系统以建立项目建设标准规范为核心&#xff0c;旨在提升数据质量与服务品质。 二、建立标准规范&#xff0c;确保数据质量 …

ansible-playbook的Temlates模块 tags模块 Roles模块

Temlates模块 jinja模板架构&#xff0c;通过模板可以实现向模板文件传参(python转义)把占位符参数传到配置文件中去,生产一个目标文本文件&#xff0c;传递变量到需要的配置文件当中 &#xff08;web开发&#xff09; nginx.conf.j2 早文件当中配置的是占位符&#xff08;声明…

GBASE南大通用数据库在Windows和Linux中创建数据源

Windows 中数据源信息可能存在于两个地方&#xff1a;在 Windows 注册表中&#xff08;对 Windows 系统&#xff09;&#xff0c; 或在一个 DSN 文件中&#xff08;对任何系统&#xff09;。 如果信息在 Windows 注册表中&#xff0c;它叫做“机器数据源”。它可能是一个“用 …

机器学习——分类评价指标

【说明】文章内容来自《机器学习——基于sklearn》&#xff0c;用于学习记录。若有争议联系删除。 1、评价指标 对于模型的评价往往会使用损失函数和评价指标&#xff0c;两者的本质是一致的。一般情况下&#xff0c;损失函数应用于训练过程&#xff0c;而评价指标应用于测试过…

整数比较(比较4个数并从小到大输出)C语言xdoj94

描述&#xff1a; 从键盘输入四个整数&#xff0c;要求按由小到大的顺序输出。 输入说明&#xff1a; 输入四个整数&#xff0c;以空格间隔。 输出说明&#xff1a; 输出排序后的整数&#xff0c;以空格间隔。 输入样例 样例1输入 -99 9 99 -9 输出样例 样例1输出 -99 -9 9 99 …

逆波兰计算器的完整代码

前置知识&#xff1a; 将中缀表达式转为List方法&#xff1a; //将一个中缀表达式转成中缀表达式的List//即&#xff1a;(3042)*5-6 》[(, 30, , 42, ), *, 5, -, 6]public static List<String> toIndixExpressionList(String s) {//定义一个List&#xff0c;存放中缀表达…

svn合并跟踪信息丢失

最近合并完了发现没有可以提交的合并信息&#xff0c;类似这样的&#xff1a; 红色部分框起来的灰色字体的&#xff0c;也就是合并信息 没有合并跟踪信息的话&#xff0c;下次合并时&#xff0c;就不知道上次合并了哪些内容&#xff0c;可能会重复合并&#xff0c;也可能漏合并…

Java反序列化链子分析-3

文章目录 前言Hessian反序列化TemplatesImplSpring AOPPartiallyComparableAdvisorHolderResin 前言 续接之前那篇Java反序列化-2的文章。 Hessian反序列化 Hessian是一种用于远程调用的二进制协议。它被广泛用于构建分布式系统中的跨平台通信&#xff0c;特别适用于Java语言…

【JS】事件循环机制

一、JS单线程、异步、同步概念 众所周知&#xff0c;JS是单线程&#xff08;如果一个线程删DOM&#xff0c;一个线程增DOM&#xff0c;浏览器傻逼了&#xff5e;所以只能单着了&#xff09;&#xff0c;虽然有webworker酱紫的多线程出现&#xff0c;但也是在主线程的控制下。we…