mysql学生成绩管理系统c
时间: 2023-12-20 11:32:06 浏览: 38
以下是一个基于MySQL的学生成绩管理系统的查询示例:
```sql
-- 查询学生的姓名和成绩
SELECT student.sname, sc.grade
FROM 学生成绩管理.student, 学生成绩管理.sc
WHERE 学生成绩管理.student.sno = 学生成绩管理.sc.sno;
```
这个查询语句将返回学生的姓名和成绩。
另外,还有一个查询示例:
```sql
-- 查询学生的学号、姓名、性别、年龄、系别和课程号
SELECT student.sno, sname, ssex, sage, sdept, cno
FROM 学生成绩管理.student, 学生成绩管理.sc
WHERE 学生成绩管理.student.sno = 学生成绩管理.sc.sno;
```
这个查询语句将返回学生的学号、姓名、性别、年龄、系别和课程号。
相关问题
数据结构学生成绩管理系统c语言
以下是一个简单的数据结构学生成绩管理系统的C语言实现,包括添加学生信息、查询学生信息、修改学生信息和删除学生信息等功能:
```c
#include <stdio.h>
#include <string.h>
#define max 100
/*定义结构体成员变量*/
typedef struct studentInformation {
char student_name[20];
char student_class[10];
int student_number;
float student_mysql;
float student_math;
float student_C;
float sum_grade;
} information;
/*定义顺序表的存储结构*/
typedef struct studentList {
information data[max];
int length;
} list;
/*初始化顺序表*/
void initList(list *L) {
L->length = 0;
}
/*添加学生信息*/
void addStudent(list *L) {
information stu;
printf("请输入学生姓名:");
scanf("%s", stu.student_name);
printf("请输入学生班级:");
scanf("%s", stu.student_class);
printf("请输入学生学号:");
scanf("%d", &stu.student_number);
printf("请输入学生数据库成绩:");
scanf("%f", &stu.student_mysql);
printf("请输入学生高数成绩:");
scanf("%f", &stu.student_math);
printf("请输入学生C语言成绩:");
scanf("%f", &stu.student_C);
stu.sum_grade = stu.student_mysql + stu.student_math + stu.student_C;
L->data[L->length] = stu;
L->length++;
printf("添加成功!\n");
}
/*查询学生信息*/
void queryStudent(list L) {
char name[20];
printf("请输入要查询的学生姓名:");
scanf("%s", name);
int flag = 0;
for (int i = 0; i < L.length; i++) {
if (strcmp(name, L.data[i].student_name) == 0) {
printf("学生姓名:%s\n", L.data[i].student_name);
printf("学生班级:%s\n", L.data[i].student_class);
printf("学生学号:%d\n", L.data[i].student_number);
printf("学生数据库成绩:%.2f\n", L.data[i].student_mysql);
printf("学生高数成绩:%.2f\n", L.data[i].student_math);
printf("学生C语言成绩:%.2f\n", L.data[i].student_C);
printf("学生总分:%.2f\n", L.data[i].sum_grade);
flag = 1;
break;
}
}
if (flag == 0) {
printf("未找到该学生信息!\n");
}
}
/*修改学生信息*/
void modifyStudent(list *L) {
char name[20];
printf("请输入要修改的学生姓名:");
scanf("%s", name);
int flag = 0;
for (int i = 0; i < L->length; i++) {
if (strcmp(name, L->data[i].student_name) == 0) {
printf("请输入学生班级:");
scanf("%s", L->data[i].student_class);
printf("请输入学生学号:");
scanf("%d", &L->data[i].student_number);
printf("请输入学生数据库成绩:");
scanf("%f", &L->data[i].student_mysql);
printf("请输入学生高数成绩:");
scanf("%f", &L->data[i].student_math);
printf("请输入学生C语言成绩:");
scanf("%f", &L->data[i].student_C);
L->data[i].sum_grade = L->data[i].student_mysql + L->data[i].student_math + L->data[i].student_C;
printf("修改成功!\n");
flag = 1;
break;
}
}
if (flag == 0) {
printf("未找到该学生信息!\n");
}
}
/*删除学生信息*/
void deleteStudent(list *L) {
char name[20];
printf("请输入要删除的学生姓名:");
scanf("%s", name);
int flag = 0;
for (int i = 0; i < L->length; i++) {
if (strcmp(name, L->data[i].student_name) == 0) {
for (int j = i; j < L->length - 1; j++) {
L->data[j] = L->data[j + 1];
}
L->length--;
printf("删除成功!\n");
flag = 1;
break;
}
}
if (flag == 0) {
printf("未找到该学生信息!\n");
}
}
int main() {
list L;
initList(&L);
int choice;
while (1) {
printf("请选择操作:\n");
printf("1.添加学生信息\n");
printf("2.查询学生信息\n");
printf("3.修改学生信息\n");
printf("4.删除学生信息\n");
printf("5.退出程序\n");
scanf("%d", &choice);
switch (choice) {
case 1:
addStudent(&L);
break;
case 2:
queryStudent(L);
break;
case 3:
modifyStudent(&L);
break;
case 4:
deleteStudent(&L);
break;
case 5:
return 0;
default:
printf("输入有误,请重新输入!\n");
break;
}
}
return 0;
}
```
学生成绩管理系统mysql课程设计
本文将介绍一个学生成绩管理系统的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`='一年级';