学生成绩管理系统mysql课程设计
时间: 2023-10-06 21:10:00 浏览: 120
本文将介绍一个学生成绩管理系统的MySQL课程设计,包括数据库设计、数据表设计和数据操作语言的实现。
一、数据库设计
1.1 数据库名称:student_management_system
1.2 数据库表:
1.2.1 学生表(student)
字段名 数据类型 主键/外键 说明
id int(11) primary key 学生编号
name varchar(20) not null 学生姓名
gender varchar(10) not null 学生性别
age int(11) not null 学生年龄
class_id int(11) foreign key 班级编号
1.2.2 班级表(class)
字段名 数据类型 主键/外键 说明
id int(11) primary key 班级编号
name varchar(20) not null 班级名称
1.2.3 课程表(course)
字段名 数据类型 主键/外键 说明
id int(11) primary key 课程编号
name varchar(20) not null 课程名称
1.2.4 成绩表(score)
字段名 数据类型 主键/外键 说明
id int(11) primary key 成绩编号
student_id int(11) foreign key 学生编号
course_id int(11) foreign key 课程编号
score int(11) not null 成绩
二、数据表设计
2.1 学生表(student)
CREATE TABLE `student` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(20) NOT NULL,
`gender` varchar(10) NOT NULL,
`age` int(11) NOT NULL,
`class_id` int(11) NOT NULL,
PRIMARY KEY (`id`),
KEY `fk_student_class` (`class_id`),
CONSTRAINT `fk_student_class` FOREIGN KEY (`class_id`) REFERENCES `class` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
2.2 班级表(class)
CREATE TABLE `class` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(20) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
2.3 课程表(course)
CREATE TABLE `course` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(20) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
2.4 成绩表(score)
CREATE TABLE `score` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`student_id` int(11) NOT NULL,
`course_id` int(11) NOT NULL,
`score` int(11) NOT NULL,
PRIMARY KEY (`id`),
KEY `fk_score_student` (`student_id`),
KEY `fk_score_course` (`course_id`),
CONSTRAINT `fk_score_course` FOREIGN KEY (`course_id`) REFERENCES `course` (`id`),
CONSTRAINT `fk_score_student` FOREIGN KEY (`student_id`) REFERENCES `student` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
三、数据操作语言的实现
3.1 插入数据
INSERT INTO `class` (`name`) VALUES ('一年级');
INSERT INTO `class` (`name`) VALUES ('二年级');
INSERT INTO `class` (`name`) VALUES ('三年级');
INSERT INTO `student` (`name`, `gender`, `age`, `class_id`) VALUES ('张三', '男', 10, 1);
INSERT INTO `student` (`name`, `gender`, `age`, `class_id`) VALUES ('李四', '女', 9, 1);
INSERT INTO `student` (`name`, `gender`, `age`, `class_id`) VALUES ('王五', '男', 11, 2);
INSERT INTO `student` (`name`, `gender`, `age`, `class_id`) VALUES ('赵六', '女', 9, 3);
INSERT INTO `course` (`name`) VALUES ('语文');
INSERT INTO `course` (`name`) VALUES ('数学');
INSERT INTO `course` (`name`) VALUES ('英语');
INSERT INTO `score` (`student_id`, `course_id`, `score`) VALUES (1, 1, 90);
INSERT INTO `score` (`student_id`, `course_id`, `score`) VALUES (1, 2, 80);
INSERT INTO `score` (`student_id`, `course_id`, `score`) VALUES (1, 3, 70);
INSERT INTO `score` (`student_id`, `course_id`, `score`) VALUES (2, 1, 85);
INSERT INTO `score` (`student_id`, `course_id`, `score`) VALUES (2, 2, 75);
INSERT INTO `score` (`student_id`, `course_id`, `score`) VALUES (2, 3, 65);
INSERT INTO `score` (`student_id`, `course_id`, `score`) VALUES (3, 1, 95);
INSERT INTO `score` (`student_id`, `course_id`, `score`) VALUES (3, 2, 85);
INSERT INTO `score` (`student_id`, `course_id`, `score`) VALUES (3, 3, 75);
INSERT INTO `score` (`student_id`, `course_id`, `score`) VALUES (4, 1, 80);
INSERT INTO `score` (`student_id`, `course_id`, `score`) VALUES (4, 2, 70);
INSERT INTO `score` (`student_id`, `course_id`, `score`) VALUES (4, 3, 60);
3.2 查询数据
-- 查询所有学生信息
SELECT * FROM `student`;
-- 查询所有班级信息
SELECT * FROM `class`;
-- 查询所有课程信息
SELECT * FROM `course`;
-- 查询所有成绩信息
SELECT * FROM `score`;
-- 查询某个学生的所有成绩信息
SELECT `score`.*, `course`.`name` AS `course_name` FROM `score` LEFT JOIN `course` ON `score`.`course_id`=`course`.`id` WHERE `score`.`student_id`=1;
-- 查询某个班级的所有学生信息
SELECT `student`.*, `class`.`name` AS `class_name` FROM `student` LEFT JOIN `class` ON `student`.`class_id`=`class`.`id` WHERE `student`.`class_id`=1;
3.3 更新数据
-- 将学生张三的年龄修改为12岁
UPDATE `student` SET `age`=12 WHERE `name`='张三';
-- 将学生张三的班级修改为2年级
UPDATE `student` SET `class_id`=2 WHERE `name`='张三';
-- 将学生张三的语文成绩修改为85分
UPDATE `score` SET `score`=85 WHERE `student_id`=1 AND `course_id`=1;
3.4 删除数据
-- 删除学生张三的所有成绩信息
DELETE FROM `score` WHERE `student_id`=1;
-- 删除学生张三的信息
DELETE FROM `student` WHERE `name`='张三';
-- 删除班级一年级的所有学生信息
DELETE FROM `student` WHERE `class_id`=1;
-- 删除班级一年级的信息
DELETE FROM `class` WHERE `name`='一年级';
阅读全文