(3) 在grade表中查询选修课程编号为0003的人数和该课程有成绩的人数。
时间: 2024-09-11 16:15:31 浏览: 214
在数据库中,若要查询特定课程编号(例如0003)的人数以及有成绩的人数,可以使用SQL(Structured Query Language)语句进行操作。这里以MySQL数据库为例,具体操作如下:
首先,假设`grade`表的结构如下:
- `student_id`:学生编号
- `course_id`:课程编号
- `grade`:成绩
要查询选修课程编号为0003的总人数,可以使用以下SQL语句:
```sql
SELECT COUNT(DISTINCT student_id) AS total_students
FROM grade
WHERE course_id = '0003';
```
接着,要查询选修课程编号为0003且有成绩的人数,可以使用以下SQL语句:
```sql
SELECT COUNT(DISTINCT student_id) AS students_with_grades
FROM grade
WHERE course_id = '0003' AND grade IS NOT NULL;
```
这两个查询分别统计了选修课程编号为0003的所有学生人数以及其中提供成绩的学生人数。
相关问题
(5)使用group by子句列出各个学生的平均成绩。 (6)使用union运算符将student_info表中姓“肖”的学生的id和name与course表的id、course_name返回在一个表中,且列名为u_编号、u_名称。 (7)嵌套查询。 ①在student_info表中查找与“林一飞”sex相同的所有学生的name、birthday。 ②使用in子查询查找所修课程编号为0002、0005的学生id、name、sex。 ③列出学号为0001的学生的grade比学号为0002号的学生的最低grade高的课程编号和分数。 (8)连接查询 student_id = student_info.id = 学号 course_id = course.id = 课程编号 ①查询分数在80-90范围内的学生的学号、name和grade信息。 ②查询学习“C语言程序设计”课程的学生的学号、name和grade。 ③查询所有男同学的选课情况,要求列出学号、name、course_name和grade。 ④查询每个学生的所选课程的最高成绩,要求列出学号、name、课程编号和grade。 ⑤查询所有学生的总成绩,要求列出学号、name、总成绩,没有选修课程的学生的总成绩为空。 ⑥ 为grade表添加数据行:学号为0004、课程编号为0006、grade为76。查询所有课程的选修情况,要求列出课程编号、course_name、选修人数,course表中没有的课程列值为空。
抱歉,我可以回答你的问题。以下是对你的问题的回答:
(5) 使用group by子句列出各个学生的平均成绩。
SELECT student_id, AVG(grade) as avg_grade
FROM grade
GROUP BY student_id;
(6) 使用union运算符将student_info表中姓“肖”的学生的id和name与course表的id、course_name返回在一个表中,且列名为u_编号、u_名称。
SELECT id AS u_编号, name AS u_名称
FROM student_info
WHERE name LIKE '肖%'
UNION
SELECT id AS u_编号, course_name AS u_名称
FROM course
WHERE id IN (
SELECT id
FROM student_info
WHERE name LIKE '肖%'
);
(7) 嵌套查询。
① 在student_info表中查找与“林一飞”sex相同的所有学生的name、birthday。
SELECT name, birthday
FROM student_info
WHERE sex = (SELECT sex FROM student_info WHERE name = '林一飞');
② 使用in子查询查找所修课程编号为0002、0005的学生id、name、sex。
SELECT id, name, sex
FROM student_info
WHERE id IN (
SELECT student_id
FROM grade
WHERE course_id IN ('0002', '0005')
);
③ 列出学号为0001的学生的grade比学号为0002号的学生的最低grade高的课程编号和分数。
SELECT course_id, grade
FROM grade
WHERE student_id = '0001' AND grade > (
SELECT MIN(grade)
FROM grade
WHERE student_id = '0002'
);
(8) 连接查询 student_id = student_info.id = 学号 course_id = course.id = 课程编号
① 查询分数在80-90范围内的学生的学号、name和grade信息。
SELECT student_info.id AS 学号, student_info.name AS name, grade AS grade
FROM grade
JOIN student_info ON grade.student_id = student_info.id
WHERE grade BETWEEN 80 AND 90;
② 查询学习“C语言程序设计”课程的学生的学号、name和grade。
SELECT student_info.id AS 学号, student_info.name AS name, grade AS grade
FROM grade
JOIN student_info ON grade.student_id = student_info.id
JOIN course ON grade.course_id = course.id
WHERE course.course_name = 'C语言程序设计';
③ 查询所有男同学的选课情况,要求列出学号、name、course_name和grade。
SELECT student_info.id AS 学号, student_info.name AS name, course.course_name AS course_name, grade.grade AS grade
FROM grade
JOIN student_info ON grade.student_id = student_info.id
JOIN course ON grade.course_id = course.id
WHERE student_info.sex = '男';
④ 查询每个学生的所选课程的最高成绩,要求列出学号、name、课程编号和grade。
SELECT student_info.id AS 学号, student_info.name AS name, course.id AS 课程编号, MAX(grade) AS grade
FROM grade
JOIN student_info ON grade.student_id = student_info.id
JOIN course ON grade.course_id = course.id
GROUP BY student_info.id, course.id;
⑤ 查询所有学生的总成绩,要求列出学号、name、总成绩,没有选修课程的学生的总成绩为空。
SELECT student_info.id AS 学号, student_info.name AS name, SUM(grade) AS 总成绩
FROM student_info
LEFT JOIN grade ON student_info.id = grade.student_id
GROUP BY student_info.id, student_info.name;
⑥ 为grade表添加数据行:学号为0004、课程编号为0006、grade为76。查询所有课程的选修情况,要求列出课程编号、course_name、选修人数,course表中没有的课程列值为空。
INSERT INTO grade (student_id, course_id, grade)
VALUES ('0004', '0006', '76');
SELECT course.id AS 课程编号, course.course_name AS course_name, COUNT(grade.student_id) AS 选修人数
FROM course
LEFT JOIN grade ON course.id = grade.course_id
GROUP BY course.id, course.course_name;
多表连接查询 (1) 查询选修了【数据库原理】的计算机系的学生学号和姓名。 (2) 查询每一门课的间接先行课(即先行课的先行课),显示课程编号和该门课程的间接先行课编号。 (3) 查询学生的学号、姓名、选修课程的名称和成绩。 (4) 查询选修了课程的学生姓名。 (5) 查询所有学生的信息和所选修的课程, 要求显示学生的学号、姓名、课程号及课程名。没有选课的同学对应的选课信息为空。 (6) 查询所有课程的课程编号、课程名称及选课人数,没有被选的课程选课人数显示为0。 (7) 列出所有学生所有可能的选修情况,要求显示学生的学号、姓名、课程号及课程名。 (8) 查找计算机系的学生选修课程数大于2 的学生的姓名、 平均成绩和选课门数,并按平均成绩降序排列。
1.
```
SELECT s.id, s.name
FROM student s
JOIN course_selection cs ON s.id = cs.student_id
JOIN course c ON cs.course_id = c.id
WHERE s.department = '计算机系'
AND c.name = '数据库原理';
```
2.
```
WITH RECURSIVE prerequisites AS (
SELECT course_id, prerequisite_id
FROM prerequisite
UNION
SELECT p.course_id, pr.prerequisite_id
FROM prerequisites pr
JOIN prerequisite p ON pr.course_id = p.prerequisite_id
)
SELECT c.id, pr.prerequisite_id
FROM course c
LEFT JOIN prerequisites pr ON c.id = pr.course_id;
```
3.
```
SELECT s.id, s.name, c.name, cs.grade
FROM student s
JOIN course_selection cs ON s.id = cs.student_id
JOIN course c ON cs.course_id = c.id;
```
4.
```
SELECT s.name
FROM student s
JOIN course_selection cs ON s.id = cs.student_id;
```
5.
```
SELECT s.id, s.name, c.id, c.name
FROM student s
LEFT JOIN course_selection cs ON s.id = cs.student_id
LEFT JOIN course c ON cs.course_id = c.id;
```
6.
```
SELECT c.id, c.name, COUNT(cs.student_id) AS num_students
FROM course c
LEFT JOIN course_selection cs ON c.id = cs.course_id
GROUP BY c.id, c.name;
```
7.
```
SELECT s.id, s.name, c.id, c.name
FROM student s
CROSS JOIN course c;
```
8.
```
WITH course_counts AS (
SELECT s.id, s.name, COUNT(cs.course_id) AS num_courses
FROM student s
JOIN course_selection cs ON s.id = cs.student_id
WHERE s.department = '计算机系'
GROUP BY s.id, s.name
HAVING COUNT(cs.course_id) > 2
),
average_grades AS (
SELECT s.id, AVG(cs.grade) AS avg_grade
FROM student s
JOIN course_selection cs ON s.id = cs.student_id
GROUP BY s.id
)
SELECT cc.name, ag.avg_grade, cc.num_courses
FROM course_counts cc
JOIN average_grades ag ON cc.id = ag.id
ORDER BY ag.avg_grade DESC;
```
阅读全文