7.统计score表中被选修过的课程门数; 8.查询未选修课程的学生信息; 9.查询C语言程序设计课程的平均分;10.将course表删除
时间: 2024-10-25 13:09:19 浏览: 62
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;
```
相关问题
数据库技术library数据库中 查询1.查询选修了课程号为16020014的课程学 生的姓名、学号及平均分。 2查询没有选修C语言程序设计的学生的姓 名、学号和专业名。
在处理这类图书馆数据库查询时,我们需要假设有一个包含学生信息、课程信息以及选课记录的数据库结构。通常这样的数据可能分布在学生表(Students)、课程表(Courses)和选课表(Enrollments)中。
1. 查询选修了课程号为16020014的学生的姓名、学号及平均分,可以使用SQL语句如下:
```sql
SELECT s.name AS student_name, s.student_id, AVG(e.grade) AS average_score
FROM Students s
JOIN Enrollments e ON s.student_id = e.student_id
WHERE e.course_id = '16020014'
GROUP BY s.student_id;
```
这个查询首先通过学生ID连接学生表和选课表,然后筛选出课程ID为16020014的记录,最后计算每个学生的平均成绩。
2. 查询没有选修C语言程序设计(假设课程名为"C Programming")的学生的姓名、学号和专业名,同样需要使用JOIN操作:
```sql
SELECT s.name AS student_name, s.student_id, s.major AS major_name
FROM Students s
LEFT JOIN Enrollments e ON s.student_id = e.student_id AND e.course_id = 'C% Language Program Design'
WHERE e.student_id IS NULL;
```
这里使用了LEFT JOIN,因为我们要找的是没有选修该课程的学生,所以如果学生没有相关的选课记录,那么他们的ID在Enrollments表中就是NULL,这将匹配到结果集。
如何用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;
}
```
以上代码仅仅是一个简单的示例,实际的选课系统可能还需要更多的功能和模块,如管理员登陆、成绩统计、选课限制等。因此,需要根据需要进行进一步的开发和完善。
阅读全文
相关推荐















