7.统计score表中被选修过的课程门数; 8.查询未选修课程的学生信息; 9.查询C语言程序设计课程的平均分;10.将course表删除
时间: 2024-10-25 18:09:19 浏览: 33
7. 要统计`score`表中被选修过的课程门数,可以通过连接`score`和`course`表,并计算每个学生的课程数目,可以这样做:
```sql
SELECT student_id, COUNT(DISTINCT cid) as total_courses
FROM score
JOIN course ON score.cid = course.cno
GROUP BY student_id;
```
8. 查询未选修课程的学生信息,首先找出学生ID,然后从`student`表中筛选出没有对应的课程ID的数据:
```sql
SELECT s.*
FROM student s
LEFT JOIN score sc ON s.student_id = sc.student_id
WHERE sc.cid IS NULL;
```
9. 计算"C语言程序设计"课程的平均分,假设`cno`为'C'表示C语言程序设计:
```sql
SELECT AVG(grade) as average_grade
FROM score
WHERE cid IN (SELECT cno FROM course WHERE cname = 'C语言程序设计');
```
10. 要删除`course`表,请谨慎操作,因为这将永久删除数据,除非有备份。如果确认无误,使用以下命令:
```sql
DROP TABLE IF EXISTS course;
```
相关问题
如何用c语言设计学生选修课程系统
好的,我可以提供一些基本的思路。学生选修课程系统通常需要包括以下几个模块:
1. 学生信息管理模块:包括学生的基本信息,如学号、姓名、性别、年龄、班级等。
2. 课程信息管理模块:包括课程的基本信息,如课程编号、课程名称、授课教师、学分等。
3. 选课模块:学生可以在这个模块中选择课程,并将所选课程存储到自己的选课清单中。
4. 学生成绩管理模块:包括学生的课程成绩,可以查询、修改、删除。
基于以上的模块,我们可以考虑使用C语言来实现。以下是一个简单的选课系统的示例代码,仅供参考:
```
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
/* 学生结构体 */
typedef struct student {
char id[10]; // 学号
char name[20]; // 姓名
char gender[10]; // 性别
int age; // 年龄
char grade[20]; // 班级
int course_num; // 选课数量
char course_list[10][20]; // 选课清单
} Student;
/* 课程结构体 */
typedef struct course {
char id[10]; // 课程编号
char name[20]; // 课程名称
char teacher[20]; // 授课教师
int credit; // 学分
} Course;
/* 全局变量 */
Student students[20]; // 学生数组,最多支持20个学生
Course courses[10]; // 课程数组,最多支持10门课程
int student_num = 0; // 学生数量
int course_num = 0; // 课程数量
/* 增加学生 */
void add_student() {
if (student_num >= 20) {
printf("学生数量已达上限!\n");
return;
}
Student student;
printf("请输入学号:");
scanf("%s", student.id);
printf("请输入姓名:");
scanf("%s", student.name);
printf("请输入性别:");
scanf("%s", student.gender);
printf("请输入年龄:");
scanf("%d", &student.age);
printf("请输入班级:");
scanf("%s", student.grade);
student.course_num = 0;
students[student_num++] = student;
printf("添加成功!\n");
}
/* 增加课程 */
void add_course() {
if (course_num >= 10) {
printf("课程数量已达上限!\n");
return;
}
Course course;
printf("请输入课程编号:");
scanf("%s", course.id);
printf("请输入课程名称:");
scanf("%s", course.name);
printf("请输入授课教师:");
scanf("%s", course.teacher);
printf("请输入学分:");
scanf("%d", &course.credit);
courses[course_num++] = course;
printf("添加成功!\n");
}
/* 选课 */
void select_course() {
char id[10];
int i, j;
printf("请输入学号:");
scanf("%s", id);
for (i = 0; i < student_num; i++) {
if (strcmp(students[i].id, id) == 0) {
if (students[i].course_num >= 10) {
printf("选课数量已达上限!\n");
return;
}
for (j = 0; j < course_num; j++) {
printf("%s\t%s\t%s\t%d\n", courses[j].id, courses[j].name, courses[j].teacher, courses[j].credit);
}
printf("请输入课程编号(输入0退出):");
scanf("%s", id);
while (strcmp(id, "0") != 0) {
int k;
for (k = 0; k < students[i].course_num; k++) {
if (strcmp(students[i].course_list[k], id) == 0) {
break;
}
}
if (k < students[i].course_num) {
printf("不能重复选课!\n");
} else {
strcpy(students[i].course_list[students[i].course_num++], id);
printf("选课成功!\n");
}
printf("请输入课程编号(输入0退出):");
scanf("%s", id);
}
return;
}
}
printf("没有找到该学生!\n");
}
/* 查询学生信息 */
void query_student() {
char id[10];
int i, j;
printf("请输入学号:");
scanf("%s", id);
for (i = 0; i < student_num; i++) {
if (strcmp(students[i].id, id) == 0) {
printf("学号:%s\n", students[i].id);
printf("姓名:%s\n", students[i].name);
printf("性别:%s\n", students[i].gender);
printf("年龄:%d\n", students[i].age);
printf("班级:%s\n", students[i].grade);
printf("选课清单:\n");
for (j = 0; j < students[i].course_num; j++) {
int k;
for (k = 0; k < course_num; k++) {
if (strcmp(students[i].course_list[j], courses[k].id) == 0) {
printf("%s\t%s\t%s\t%d\n", courses[k].id, courses[k].name, courses[k].teacher, courses[k].credit);
break;
}
}
}
return;
}
}
printf("没有找到该学生!\n");
}
/* 修改学生成绩 */
void modify_score() {
char id[10];
int i, j;
printf("请输入学号:");
scanf("%s", id);
for (i = 0; i < student_num; i++) {
if (strcmp(students[i].id, id) == 0) {
printf("选课清单:\n");
for (j = 0; j < students[i].course_num; j++) {
int k;
for (k = 0; k < course_num; k++) {
if (strcmp(students[i].course_list[j], courses[k].id) == 0) {
printf("%s\t%s\t%s\t%d\n", courses[k].id, courses[k].name, courses[k].teacher, courses[k].credit);
break;
}
}
}
printf("请输入要修改的课程编号(输入0退出):");
scanf("%s", id);
while (strcmp(id, "0") != 0) {
int k;
for (k = 0; k < students[i].course_num; k++) {
if (strcmp(students[i].course_list[k], id) == 0) {
printf("请输入成绩:");
scanf("%d", &students[i].score[k]);
break;
}
}
if (k == students[i].course_num) {
printf("该学生没有选修该课程!\n");
}
printf("请输入要修改的课程编号(输入0退出):");
scanf("%s", id);
}
return;
}
}
printf("没有找到该学生!\n");
}
/* 主函数 */
int main() {
int choice;
printf("欢迎使用学生选修课程系统!\n");
while (1) {
printf("请选择操作:\n");
printf("1. 添加学生\n");
printf("2. 添加课程\n");
printf("3. 选课\n");
printf("4. 查询学生信息\n");
printf("5. 修改学生成绩\n");
printf("6. 退出系统\n");
printf("请输入操作编号:");
scanf("%d", &choice);
switch (choice) {
case 1:
add_student();
break;
case 2:
add_course();
break;
case 3:
select_course();
break;
case 4:
query_student();
break;
case 5:
modify_score();
break;
case 6:
printf("谢谢使用!\n");
return 0;
default:
printf("无效操作!\n");
break;
}
}
return 0;
}
```
以上代码仅仅是一个简单的示例,实际的选课系统可能还需要更多的功能和模块,如管理员登陆、成绩统计、选课限制等。因此,需要根据需要进行进一步的开发和完善。
用c语言设计和实现一个简单的学生管理系统,具有以下功能: 1. 学生信息录入:可以录入学生的基本信息,包括学号、姓名、性别、年龄、所在院系等信息。要求支持多名学生信息的录入。 2. 学生信息查询:可以按学号或姓名进行学生信息的查询,找到相应学生的基本信息。 3. 学生成绩录入:可以为每名学生录入多门课程的成绩,包括课程名称、学分、成绩等。 4. 学生成绩查询:可以按学号和课程名称查询某名学生的指定课程成绩。 5. 课程平均分查询:可以查询每门课程的平均成绩。 6. 学生总分统计:可以统计每名学生的总学分和总成绩,以及根据总成绩计算学生的平均分。 该系统需要提供一个菜单界面,让用户选择不同的功能;需要定义学生信息结构体和成绩结构体。
好的,以下是一个简单的学生管理系统的C语言实现,包括上述所述的功能:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
// 定义学生信息结构体
typedef struct {
char id[20]; // 学号
char name[20]; // 姓名
char sex[5]; // 性别
int age; // 年龄
char department[20]; // 所在院系
} Student;
// 定义课程成绩结构体
typedef struct {
char course_name[20]; // 课程名称
int credit; // 学分
int score; // 成绩
} Course;
// 定义全局变量
int student_count = 0; // 学生数量
Student students[100]; // 学生信息数组
Course courses[100][10]; // 课程成绩数组, 最多10门课程
// 函数声明
void print_menu();
void add_student();
void search_student();
void add_score();
void search_score();
void print_course_average();
void print_student_statistics();
// 主函数
int main() {
int choice;
do {
print_menu();
scanf("%d", &choice);
switch (choice) {
case 1:
add_student();
break;
case 2:
search_student();
break;
case 3:
add_score();
break;
case 4:
search_score();
break;
case 5:
print_course_average();
break;
case 6:
print_student_statistics();
break;
case 0:
printf("感谢使用,再见!\n");
break;
default:
printf("无效选项,请重新选择!\n");
break;
}
} while (choice != 0);
return 0;
}
// 打印菜单
void print_menu() {
printf("\n===== 学生管理系统 =====\n");
printf("1. 学生信息录入\n");
printf("2. 学生信息查询\n");
printf("3. 学生成绩录入\n");
printf("4. 学生成绩查询\n");
printf("5. 课程平均分查询\n");
printf("6. 学生总分统计\n");
printf("0. 退出\n");
printf("========================\n");
printf("请选择:");
}
// 添加学生信息
void add_student() {
printf("请输入学生信息:\n");
printf("学号:");
scanf("%s", students[student_count].id);
printf("姓名:");
scanf("%s", students[student_count].name);
printf("性别:");
scanf("%s", students[student_count].sex);
printf("年龄:");
scanf("%d", &students[student_count].age);
printf("院系:");
scanf("%s", students[student_count].department);
student_count++;
printf("学生信息添加成功!\n");
}
// 查询学生信息
void search_student() {
int option;
printf("请选择查询方式:\n");
printf("1. 按学号查询\n");
printf("2. 按姓名查询\n");
printf("请选择:");
scanf("%d", &option);
switch (option) {
case 1:
printf("请输入要查询的学生学号:");
char id[20];
scanf("%s", id);
for (int i = 0; i < student_count; i++) {
if (strcmp(id, students[i].id) == 0) {
printf("学号\t姓名\t性别\t年龄\t所在院系\n");
printf("%s\t%s\t%s\t%d\t%s\n", students[i].id, students[i].name, students[i].sex, students[i].age, students[i].department);
return;
}
}
printf("未找到该学生!\n");
break;
case 2:
printf("请输入要查询的学生姓名:");
char name[20];
scanf("%s", name);
for (int i = 0; i < student_count; i++) {
if (strcmp(name, students[i].name) == 0) {
printf("学号\t姓名\t性别\t年龄\t所在院系\n");
printf("%s\t%s\t%s\t%d\t%s\n", students[i].id, students[i].name, students[i].sex, students[i].age, students[i].department);
return;
}
}
printf("未找到该学生!\n");
break;
default:
printf("无效选项,请重新选择!\n");
break;
}
}
// 添加学生成绩
void add_score() {
printf("请输入学生学号:");
char id[20];
scanf("%s", id);
int index = -1; // 记录该学生在数组中的下标
for (int i = 0; i < student_count; i++) {
if (strcmp(id, students[i].id) == 0) {
index = i;
break;
}
}
if (index == -1) {
printf("未找到该学生!\n");
return;
}
printf("请输入课程数目:");
int course_count;
scanf("%d", &course_count);
for (int i = 0; i < course_count; i++) {
printf("请输入第%d门课程的信息:\n", i+1);
printf("课程名称:");
scanf("%s", courses[index][i].course_name);
printf("学分:");
scanf("%d", &courses[index][i].credit);
printf("成绩:");
scanf("%d", &courses[index][i].score);
}
printf("学生成绩添加成功!\n");
}
// 查询学生成绩
void search_score() {
printf("请输入学生学号:");
char id[20];
scanf("%s", id);
int index = -1; // 记录该学生在数组中的下标
for (int i = 0; i < student_count; i++) {
if (strcmp(id, students[i].id) == 0) {
index = i;
break;
}
}
if (index == -1) {
printf("未找到该学生!\n");
return;
}
printf("请输入要查询的课程名称:");
char course_name[20];
scanf("%s", course_name);
for (int i = 0; i < 10; i++) {
if (strcmp(courses[index][i].course_name, course_name) == 0) {
printf("学号\t姓名\t课程\t学分\t成绩\n");
printf("%s\t%s\t%s\t%d\t%d\n", students[index].id, students[index].name, courses[index][i].course_name, courses[index][i].credit, courses[index][i].score);
return;
}
}
printf("未找到该课程!\n");
}
// 查询课程平均分
void print_course_average() {
printf("请输入要查询的课程名称:");
char course_name[20];
scanf("%s", course_name);
int count = 0; // 统计选修该课程的学生数目
int total_score = 0; // 统计选修该课程的学生总成绩
for (int i = 0; i < student_count; i++) {
for (int j = 0; j < 10; j++) {
if (strcmp(courses[i][j].course_name, course_name) == 0) {
count++;
total_score += courses[i][j].score;
break;
}
}
}
if (count == 0) {
printf("无学生选修该课程!\n");
return;
}
double average_score = (double)total_score / count;
printf("%s课程的平均成绩为:%.2f\n", course_name, average_score);
}
// 查询学生总分统计
void print_student_statistics() {
printf("请输入要查询的学生学号:");
char id[20];
scanf("%s", id);
int index = -1; // 记录该学生在数组中的下标
for (int i = 0; i < student_count; i++) {
if (strcmp(id, students[i].id) == 0) {
index = i;
break;
}
}
if (index == -1) {
printf("未找到该学生!\n");
return;
}
int total_credit = 0; // 统计学生总学分
int total_score = 0; // 统计学生总成绩
for (int i = 0; i < 10; i++) {
if (courses[index][i].score != 0) { // 成绩为0表示该门课程未选修
total_credit += courses[index][i].credit;
total_score += courses[index][i].score;
}
}
double average_score = (double)total_score / total_credit;
printf("该学生的总学分为:%d,总成绩为:%d,平均成绩为:%.2f\n", total_credit, total_score, average_score);
}
```
这个程序定义了 `Student` 结构体和 `Course` 结构体来存储学生基本信息和课程成绩信息。使用全局变量 `students` 和 `courses` 数组来存储所有学生的信息和课程成绩。程序通过菜单来提供不同的功能,例如添加学生信息、查询学生信息、添加学生成绩、查询学生成绩、查询课程平均分和查询学生总分统计。在每个功能函数中,程序通过遍历数组来查找学生和成绩信息,并进行相应的操作。
阅读全文