基于Java + Swing + MySQL的学生选课及成绩管理系统(Java课程设计)
创始人
2025-01-10 00:05:28
0

目录

  • 开发工具
  • 系统结构
  • 功能展示
    • 登录与注册界面(通用)
    • 主界面(通用)
    • 学生信息查询界面(学生用户)
    • 学生信息管理界面(教师用户 管理员用户)
    • 学生选课界面(学生用户)
    • 学生课程成绩查询界面(学生用户)
    • 学生课程成绩管理界面(教师用户 管理员用户)
    • 学生课程管理界面(管理员用户)
    • 修改密码界面(通用)
  • 数据库设置
    • 数据库E-R图
    • 创建和管理数据库的SQL命令
  • 源码及项目配置
  • 结尾


开发工具

工具说明
JDK 1.8Java环境
IDEA编译器
MySQL 8.0.36数据库
Navicat 16数据库图形化管理工具

系统结构

在这里插入图片描述


功能展示

登录与注册界面(通用)

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


主界面(通用)

在这里插入图片描述

学生、教师和管理员的主界面相同,菜单栏里功能不同。


学生信息查询界面(学生用户)

在这里插入图片描述

采用数据库模糊搜索,支持关键词搜索。

选中表格中的一行数据后点击底部按钮,可以查看详细信息。

在这里插入图片描述


学生信息管理界面(教师用户 管理员用户)

在学生查询的基础上,增加了添加和删除的功能。由于学生的学号与选课联系的学号形成外键约束,当这里删除某个学生,对应该学生的所有课程成绩及选课都会删除。

在这里插入图片描述

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


学生选课界面(学生用户)

在这里插入图片描述

在表里选中对应课程行,再填入学号,点击添加按钮,即可添加课程,学生添加好的课程,显示是无分数的,需要教师或管理员进行成绩管理,就会有分数。

在这里插入图片描述


学生课程成绩查询界面(学生用户)

学生刚选课完,课程成绩为空,需要教师或管理员进行成绩管理,就会有分数。

在这里插入图片描述


学生课程成绩管理界面(教师用户 管理员用户)

在这里插入图片描述

老规矩选中对应的一行的课程成绩,就能进行修改和删除。

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


学生课程管理界面(管理员用户)

可将学生的课程增加与删除。由于课程的课程号与选课联系的课程号形成外键约束,当这里删除某个课程,对应该课程的所有课程成绩及该选课都会删除。

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

在这里插入图片描述


修改密码界面(通用)

在这里插入图片描述

在这里插入图片描述


数据库设置

数据库E-R图

在这里插入图片描述


创建和管理数据库的SQL命令

-- 创建数据库并使用 utf8mb4 字符集和排序规则 CREATE DATABASE studata CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; USE studata;  -- 创建 user_stu 表 CREATE TABLE `user_stu` (     `username` VARCHAR(30) PRIMARY KEY,     `password` VARCHAR(30) NOT NULL ) ENGINE=INNODB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;  -- 创建 user_tch 表 CREATE TABLE `user_tch` (     `username` VARCHAR(30) PRIMARY KEY,     `password` VARCHAR(30) NOT NULL ) ENGINE=INNODB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;  -- 创建 user_admin 表 CREATE TABLE `user_admin` (     `username` VARCHAR(30) PRIMARY KEY,     `password` VARCHAR(30) NOT NULL ) ENGINE=INNODB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;  -- 创建 stu 表 CREATE TABLE `stu` (     `name` VARCHAR(20) NOT NULL,     `gender` CHAR(2) NOT NULL,     `sno` CHAR(12) NOT NULL UNIQUE PRIMARY KEY,     `major` VARCHAR(12) DEFAULT NULL ) ENGINE=INNODB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;  -- 创建 course 表 CREATE TABLE `course` (     `cno` CHAR(4) NOT NULL,     `cname` VARCHAR(20) DEFAULT NULL,     `cteacher` VARCHAR(20) DEFAULT NULL,     `credit` INT(11) DEFAULT NULL,     PRIMARY KEY (`cno`) USING BTREE ) ENGINE=INNODB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;  -- 创建 sc 表 CREATE TABLE `sc` (     `sno` CHAR(12) NOT NULL,     `cno` CHAR(4) NOT NULL,     `score` INT(11) DEFAULT NULL,     PRIMARY KEY (`sno`, `cno`),     CONSTRAINT `fk_sc_cno` FOREIGN KEY (`cno`) REFERENCES `course` (`cno`) ON DELETE CASCADE,     CONSTRAINT `fk_sc_sno` FOREIGN KEY (`sno`) REFERENCES `stu` (`sno`) ON DELETE CASCADE ) ENGINE=INNODB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;  -- 插入 user_admin 表数据 INSERT INTO `user_admin` (`username`, `password`) VALUES ('admin', '123'); -- 插入 user_tch 表数据 INSERT INTO `user_tch` (`username`, `password`) VALUES ('tch', '123'); -- 插入 user_stu 表数据 INSERT INTO `user_stu` (`username`, `password`) VALUES ('stu', '123');  -- 插入 course 表数据 INSERT INTO `course` (`cno`, `cname`, `cteacher`, `credit`) VALUES ('0001', '计算机应用基础', '张老师', 1), ('0002', 'C++程序设计', '李老师', 2), ('0003', '数据库', '王老师', 3), ('0004', '计算机操作系统', '赵老师', 2), ('0005', '英语', '陈老师', 2), ('0006', '高等数学', '刘老师', 1), ('0007', '软件工程', '孙老师', 2), ('0008', '算法导论', '周老师', 3), ('0009', 'Java面向对象程序设计', '吴老师', 4);  -- 插入 stu 表数据 INSERT INTO `stu` (`name`, `gender`, `sno`, `major`) VALUES ('王大勇', '男', '202220010401', '计算机科学与技术'), ('李志成', '男', '202220010402', '软件工程'), ('赵小明', '男', '202220010403', '计算机科学与技术'), ('刘慧敏', '女', '202220010404', '物联网工程'), ('陈光明', '男', '202220010405', '智能科学与技术'), ('吴小丽', '女', '202220010406', '智能科学与技术'), ('林美玲', '女', '202220010407', '计算机科学与技术');  -- 插入 sc 表数据 INSERT INTO `sc` (`sno`, `cno`, `score`) VALUES ('202220010401', '0001', 85), ('202220010401', '0002', 78), ('202220010401', '0003', 92), ('202220010402', '0001', 79), ('202220010402', '0004', 85), ('202220010403', '0002', 88), ('202220010403', '0005', 90), ('202220010404', '0003', 87), ('202220010404', '0006', 95), ('202220010405', '0002', 82), ('202220010405', '0007', 88), ('202220010406', '0003', 90), ('202220010406', '0008', 92), ('202220010407', '0003', 85), ('202220010407', '0009', 89); 

源码及项目配置

源码已经上传到Github上,可以直接下载用IDEA打开项目。

Github项目链接: https://github.com/HongsCai/StuSystem

可在 src/com/service/JdbcConfig 中进行数据库账号配置,在项目中,我将数据库用户名设置为 root,数据库密码设置为 123456,可以根据需要自行修改。

另外数据库配置文件在 src/resources/sql/ 下。

初始在数据库中记录的登录账号:

管理员: 账号:admin 密码:123
教师: 账号:tch 密码:123
学生: 账号:stu 密码:123



结尾

Java期末课程设计,用时两三天简单设计实现了下学生选课及成绩管理系统(一点都不简单,界面改来改去折磨得狠,还得另学数据库)(下学期才学数据库,这学期课程设计就必须得用😨),界面不美观、单调,系统功能较少,还请多多见谅😭。前几个月开始学算法想卷竞赛,但是做题做不动,而且提升也慢😭,感觉脑袋笨笨的,被灵神群里的算法巨佬们吓晕😨,侥幸混了个传智杯国一和蓝桥杯国二,至于XCPC不敢碰瓷。不仅菜而且摆,现在收收心开始好好学Java😇🙏。

相关内容

热门资讯

玩家必备科技微扑克智能原来是真... 玩家必备科技微扑克智能原来是真的有挂,太夸张了原来真的是有挂,详细教程(有挂方针);微扑克是一款益智...
攻略讲解!微扑克规律辅助器挂(... 攻略讲解!微扑克规律辅助器挂(辅助挂)原来是有挂(有挂方针)详细教程(哔哩哔哩);1、很好的工具软件...
终于清楚《wPk辅助透视》太坑... 终于清楚《wPk辅助透视》太坑了果然确实真的有挂(有挂猫腻);是一款可以让一直输的玩家,快速成为一个...
重大通报线上Wepoke软件透... 重大通报线上Wepoke软件透明挂!太坑了其实是有挂的(有挂方针)(哔哩哔哩);最新软件透明挂直接下...
五分钟了解!WPK玄学(WPk... 五分钟了解!WPK玄学(WPk)辅助透视!(辅助透视)详细教程(2022已更新)(哔哩哔哩);1.W...
必备科技微扑克数据原来是有挂,... 必备科技微扑克数据原来是有挂,太夸张了原来真的是有挂,详细教程(今日头条);1.微扑克 ai辅助创建...
技术分享《Wepoke实测》软... 【福星临门,好运相随】;技术分享《Wepoke实测》软件透明挂!(软件)透明挂辅助器(2022已更新...
玩家科普!微扑克数据外挂辅助下... 玩家科普!微扑克数据外挂辅助下载(辅助挂)原来真的是有挂(竟然有挂)详细教程(哔哩哔哩);亲真的是有...
新手必备wePOke软件透明挂... 亲,这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特别好,总是好牌,...
wpk教程!wpk德州(WPk... 您好,wpk这款游戏可以开挂的,确实是有挂的,需要了解加微【841106723】很多玩家在这款游戏中...