基于MyBatis的学生选课管理系统

基于 MyBatis 的学生选课管理系统 1 需求分析 采用 MyBatis 框架实现基于 DAO 设计模式的学生选课管理系统: 用户角色划分:学生

本文包含相关资料包-----> 点击直达获取<-------

基于 MyBatis 的学生选课管理系统

1 需求分析

采用 MyBatis 框架实现基于 DAO 设计模式的学生选课管理系统:

用户角色划分:学生、教师、管理员

各角色基本功能如下:

学生角色:登陆、查看所有课程、选课、退选、成绩查询统计、修改密码

教师角色:登陆、查看自己担任的课程信息,查看课程的选课名单、名单导出、输入某课程学生成绩、成绩导出、个人信息维护

管理员角色:登陆、用户管理(教师用户,学生用户)、课程管理。

具体要求如下:

1.1 用户登陆

当程序运行时,显示“欢迎使用教务管理系统,请登陆”,提示用户依次输入用户名及其密码,当用户名及密码不正确时,显示提示信息“用户名或密码不正确,请重新输入”,用户最多可以尝试 3 次,若输入 3 次均不正确,则给出提示信息“最多只能尝试 3 次”,退出系统;

1.2 功能

1.2.1 增加用户信息

角色身份为“管理员”的用户进入后,在选择 1 时,即可添加用户信息,从键盘依次录入信息,输入格式为“用户名,id,密码,角色”,添加完成后提示“信息添加成功!”。

1.2.2 删除用户信息

角色身份为“管理员”的用户进入后,在选择 2 时,根据提示“请输入删除的账号 id:”输入账号 id 后,即可完成用户的删除,在删除成功后提示“信息删除成功!”。

1.2.3 增加课程信息

角色身份为“管理员”的用户进入后,在选择 3 时,即可增加课程信息,从键盘依次录入信息,输入格式为“教师 ID,教师姓名,课程编号,课程名,课程学时”,添加完成后提示“课程添加成功!”。

1.2.4 删除课程信息

角色身份为“管理员”的用户进入后,在选择 4 时,根据提示“请输入删除的课程编号:”输入课程编号后,即可完成课程的删除,在删除成功后提示“课程删除成功!”。

1.2.5 返回主菜单

角色身份为“管理员”的用户进入后,在选择 6 时,即可返回主菜单并重新进行选择。

1.3 修改账户密码

当选择修改密码时,显示“请输入当前用户的原密码:”,若原密码不正确,则提示“密码不正确!”,并返回主菜单;若输入正确后,则显示“请输入新的密码:”,输入完成后要求再次确认密码,两次输入一致则密码更改成功,并提示“修改成功!”并返回主菜单。

1.4 退出

选择退出时,显示“感谢您的使用!”并退出系统。

2 系统设计

2.1 用户用例图

系统分为学生,教师,管理员三个角色,各角色的用户用例如下图 2-1 所示:

图 2-1 用户用例图

2.2 ER 图

数据库设计 4 张表,用户表,成绩表,课程表,选课记录表,对应的 ER 图如图所示。

2.3 UML 类图(Class Diagram)

2.3.1 登陆

登录操作需要验证用户名,密码,只有当用户名和密码同时存在即用户存在的情况下才能成功登录系统,否则会提示错误信息,具体流程如图所示。

2.3.2 查看课程

显示数据库中存在的所有课程信息,用户确认信息后,返回主菜单。

查看课程功能的活动图如图所示。

2.3.3 学生选课/退选

显示“请输入选课/退选课程号:”,如果课程号不存在于数据库中,则显示“课程不存在”,如果课程号存在,则将该课程增加至该学生的学生信息中或从学生信息中移除。学生选课/退选功能的活动图如图所示。

2.3.4 学生成绩查询

当选择成绩查询时,显示该学生学习信息中的姓名,学号,课程,成绩字段。确认信息后返回主菜单。学生成绩查询的活动图如图所示。

2.3.5 修改密码

显示“请输入当前用户的原密码:”,若原密码不正确,则提示“原密码输入不正确,请重新输入”,输入正确后,显示“请设置新的密码:”,输入的密码必须满足必要的复杂性,如果不符合要求,则提示“您的密码不符合复杂性要求(密码长度不少于 6 个字符,至少有一个小写字母,至少有一个大写字母,至少一个数字),请重新输入:”,输入成功后,显示“请输入确认密码:”,若两次输入不一样,则提示“两次输入的密码必须一致,请重新输入确认密码:”,输入成功后,修改数据库中的用户表,并提示“成功修改密码”,返回主界面。修改密码功能的活动图如图所示。

2.3.6 教师查看自己担任课程信息

当用户为教师身份登录时,选择“查看自己所任课程信息”,显示该教师用户信息中的姓名,教师号,课程字段。确认信息后返回主菜单。教师查看自己担任课程信息的活动图如图所示。

2.3.7 学生成绩查询

当选择成绩查询时,显示该学生学习信息中的姓名,学号,课程,成绩字段。确认信息后返回主菜单。学生成绩查询的活动图如图所示。

2.3.8 学生成绩查询

当选择成绩查询时,显示该学生学习信息中的姓名,学号,课程,成绩字段。确认信息后返回主菜单。学生成绩查询的活动图如图所示。

3 系统实现

3.1 项目结构

3.2 配置文件

在项目下新建 Source Folder,名为 config

3.2.1 log4j.properties 文件

java DBDRIVER=com.mysql.jdbc.Driver DBURL=jdbc:mysql://localhost:3306/testdb?useUnicode=true&characterEncoding=UTF-8 DBUSER=su PASSWORD=Java1212

3.2.3 mybatis-config.xml 文件

```xml

<!-- 配置mapper映射文件 -->
<mappers>
    <mapper resource="dao/mapper/UserMapper.xml" /> 
</mappers>

```

3.3 VO 类 User.java

```java package vo;

import java.util.Date;

public class User { private Long id;

private Long usernumber;

private String username;

private String password;

private Long classid;

private Integer credit;

private Integer identity;

private String imageurl;

private Integer sex;

private Date createtime;

public Long getId() {
    return id;
}

public void setId(Long id) {
    this.id = id;
}

public Long getUsernumber() {
    return usernumber;
}

public void setUsernumber(Long usernumber) {
    this.usernumber = usernumber;
}

public String getUsername() {
    return username;
}

public void setUsername(String username) {
    this.username = username == null ? null : username.trim();
}

public String getPassword() {
    return password;
}

public void setPassword(String password) {
    this.password = password == null ? null : password.trim();
}

public Long getClassid() {
    return classid;
}

public void setClassid(Long classid) {
    this.classid = classid;
}

public Integer getCredit() {
    return credit;
}

public void setCredit(Integer credit) {
    this.credit = credit;
}

public Integer getIdentity() {
    return identity;
}

public void setIdentity(Integer identity) {
    this.identity = identity;
}

public String getImageurl() {
    return imageurl;
}

public void setImageurl(String imageurl) {
    this.imageurl = imageurl == null ? null : imageurl.trim();
}

public Integer getSex() {
    return sex;
}

public void setSex(Integer sex) {
    this.sex = sex;
}

public Date getCreatetime() {
    return createtime;
}

public void setCreatetime(Date createtime) {
    this.createtime = createtime;
}

@Override
public String toString() {
    return "User [id=" + id + ", usernumber=" + usernumber + ", username=" + username + ", password=" + password
            + ", classid=" + classid + ", credit=" + credit + ", identity=" + identity + ", imageurl=" + imageurl
            + ", sex=" + sex + ", createtime=" + createtime + "]";
}

} ```

3.4 DAO 接口类 IUserDAO.java

```java package dao;

import java.util.List; import java.util.Map;

import vo.User;

public interface UserDao { int deleteByPrimaryKey(Long id);

int insert(User record);

int insertSelective(User record);

User selectByPrimaryKey(Long id);

int updateByPrimaryKeySelective(User record);

int updateByPrimaryKey(User record);

List<Map<String, Object>> studentsCourseSelection(long courseId);

// 根据学号查询该用户是否存在

public String selectUserByUserNumber(long userNumber);

//验证登录信息

public Map<String, Object> verifyByUser(long userNumber, String password, int identity);

// 修改密码

boolean updatePwd(long id, String password);



//查询所有的用户

List<Map<String, Object>> selectAllUser();

//分页查询所有的用户

Map<String, Object> selectAllUser(int pageNum,int pageSize,String whereSql);

//批量删除用户

boolean deleteByPrimaryKeys(String ids);

//查询用户的数量

Map<String, Object> selectUserNumber();

//根据用户角色获取该角色的所有的用户

List<Map<String, Object>> selectAllUserByIdentity(int identity);

//老师根据条件查询学生列表

Map<String, Object> selectUserByTeacher(int pageNum, int pageSize, String whereSql);


Map<String, Object> selectAllStudent(int pageNum, int pageSize, String whereSql);

//根据学号查询用户

Map<String, Object> selectOneByUserNumber(long userNumber);

// 根据学生id修改学分

boolean updateCreditById(long id, int credit);

} ```

3.5 接口映射文件 UserMapper.xml

```xml

id, userNumber, username, password, classid, credit, identity, imageUrl, sex, createTime delete from user where id = #{id,jdbcType=BIGINT} insert into user (id, userNumber, username, password, classid, credit, identity, imageUrl, sex, createTime) values (#{id,jdbcType=BIGINT}, #{usernumber,jdbcType=BIGINT}, #{username,jdbcType=VARCHAR}, #{password,jdbcType=VARCHAR}, #{classid,jdbcType=BIGINT}, #{credit,jdbcType=INTEGER}, #{identity,jdbcType=INTEGER}, #{imageurl,jdbcType=VARCHAR}, #{sex,jdbcType=INTEGER}, #{createtime,jdbcType=TIMESTAMP}) insert into user id, userNumber, username, password, classid, credit, identity, imageUrl, sex, createTime, #{id,jdbcType=BIGINT}, #{usernumber,jdbcType=BIGINT}, #{username,jdbcType=VARCHAR}, #{password,jdbcType=VARCHAR}, #{classid,jdbcType=BIGINT}, #{credit,jdbcType=INTEGER}, #{identity,jdbcType=INTEGER}, #{imageurl,jdbcType=VARCHAR}, #{sex,jdbcType=INTEGER}, #{createtime,jdbcType=TIMESTAMP}, update user userNumber = #{usernumber,jdbcType=BIGINT}, username = #{username,jdbcType=VARCHAR}, password = #{password,jdbcType=VARCHAR}, classid = #{classid,jdbcType=BIGINT}, credit = #{credit,jdbcType=INTEGER}, identity = #{identity,jdbcType=INTEGER}, imageUrl = #{imageurl,jdbcType=VARCHAR}, sex = #{sex,jdbcType=INTEGER}, createTime = #{createtime,jdbcType=TIMESTAMP}, where id = #{id,jdbcType=BIGINT} update user set userNumber = #{usernumber,jdbcType=BIGINT}, username = #{username,jdbcType=VARCHAR}, password = #{password,jdbcType=VARCHAR}, classid = #{classid,jdbcType=BIGINT}, credit = #{credit,jdbcType=INTEGER}, identity = #{identity,jdbcType=INTEGER}, imageUrl = #{imageurl,jdbcType=VARCHAR}, sex = #{sex,jdbcType=INTEGER}, createTime = #{createtime,jdbcType=TIMESTAMP} where id = #{id,jdbcType=BIGINT} ```

4 系统总结

主要存在的问题就是对 MyBatis 并不是很熟练,环境配置还存在很大问题。还存在很多 bug,还有一些功能还没完善。准备假期再重新系统的学习一遍 Java,争取把漏补上。

参考文献

  • 轻量级J2EE架构下的学生选课系统研究(武汉理工大学·孔国城)
  • 新疆财经大学选课系统的设计与实现(电子科技大学·阿孜古丽)
  • 轻量级J2EE架构下的学生选课系统研究(武汉理工大学·孔国城)
  • 基于B/S结构的网络选课系统设计与实现(黑龙江大学·陈天凯)
  • 基于B/S结构的网络选课系统设计与实现(黑龙江大学·陈天凯)
  • 基于B/S模式的学生选课系统的设计与实现(天津大学·王鑫)
  • 轻量级J2EE架构下的学生选课系统研究(武汉理工大学·孔国城)
  • 学生管理系统的设计与实现(电子科技大学·贾林蓉)
  • 基于Web的高校选课系统的设计与实现(电子科技大学·谢慧萍)
  • 基于B/S模式的高职院校选课系统的设计与实现(电子科技大学·左炳才)
  • 轻量级J2EE架构下的学生选课系统研究(武汉理工大学·孔国城)
  • 基于B/S模式的高职院校选课系统的设计与实现(电子科技大学·左炳才)
  • 基于SSH框架的教学资源管理系统的设计与实现(北京工业大学·李晖)
  • 基于B/S结构的网络选课系统设计与实现(黑龙江大学·陈天凯)
  • 基于校园网的高中选课系统的设计与实现(天津师范大学·马士翠)

本文内容包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主题。发布者:源码导航 ,原文地址:https://m.bishedaima.com/yuanma/35716.html

相关推荐

  • 基于SSM框架的电影院售票系统

    这是一个🔥🔥基于SSM框架的电影院售票系统🔥🔥的项目源码,开发语言Java,开发环境Idea/Eclipse,这个 SSM框架电影院售票系统开发技术栈为SSM项目,可以作为毕业设计课程设计作业使用SSM框架实现一个电影院售票平台
    2024年05月23日
    15 1 2
  • 基于Python的中文自动分词实验

    中文自动分词实验 实验内容 使用任意分词方法进行分词 实验要求和目的 使用任意分词方法实现汉语自动分词; 给出至少 1000 个句子的分词结果(以附件形式); 计算出分词结果的正确率
    2024年05月14日
    2 1 1
  • 基于springboot的在线慕课学习网站,基于javaweb的mooc网站

    设计并实现基于Spring Boot的在线慕课学习网站和基于JavaWeb的MOOC网站是当前计算机科学领域的研究热点之一,随着互联网的普及和技术的不断发展,人们对于便捷高效的在线学习方式的需求日益增加
    2024年05月07日
    9 1 1
  • 基于Python制作的记忆翻牌小游戏

    基于 Python 制作的记忆翻牌小游戏 导语 昨天看到有留言竟然说我是月更博主,我明明更新地这么勤快(心虚,jpg),看吧,昨天刚更新过,今天又来更新了
    2024年05月14日
    18 1 3
  • 基于SpringBoot框架的旅游管理系统

    这是一套采用🔥🔥SpringBoot为核心的旅游管理系统的源代码实现,主要编程语言为Java,并结合了Vue技术进行开发,开发工具选择的是Idea或Eclipse,此项目是一个精简版的旅游管理应用
    2024年05月23日
    4 1 2
  • 基于Python制作小恐龙游戏

    基于 Python 设计的小恐龙小游戏 本来想带大家用遗传算法再训一波龙的,于是把自己之前写的仿谷歌浏览器小恐龙代码找了出来,就是这个: Python 制作小游戏(七) 想在它基础上加 AI 控制的代码的
    2024年05月14日
    5 1 1
  • 基于PHP和Web的subversion用户管理系统

    基于PHP和Web的subversion用户管理系统 摘 要 本系统主要是基于Web的subversion系统的用户管理系统,在开源软件世界,并行版本系统(cvs)一直是版本控制长久以来的唯一选择
    2024年05月14日
    2 1 1
  • 基于JSP和MySQL的电脑彩票销售管理系统的设计与实现

    基于Jsp和Mysql的电子产品销售管理系统 1 绪论 随着科技水平的飞速发展,计算机走进了千家万户,人们开始越来越多地利用计算机解决和日常生活相关的各种问题
    2024年05月14日
    4 1 1
  • 构造正规式r1|r2

    近年来,随着计算机科学领域的迅速发展,正规式与自动机理论作为编译原理等诸多领域的基础,备受关注,在编写程序中,正规式的构造是一项常见而且关键的任务,特别是在涉及到复杂文本匹配与处理的场景下
    2024年05月07日
    7 1 3
  • 基于JAVA实现的超级马里奥(Super Mario)游戏

    基于JAVA实现的超级马里奥(Super Mario)游戏 一,项目简介 刚进入的时候会有一个界面,为地图编辑器,可以使用此编辑器进行地图编辑,地图编辑器的内容包括:关卡
    2024年05月14日
    6 1 2

发表回复

登录后才能评论