MySQL建表查询选修了4号课程的学生的学号和成绩,结果按成绩降序排列
时间: 2024-10-16 16:06:07 浏览: 73
在MySQL中,你可以使用以下SQL查询来获取选修了4号课程的学生的学号和成绩,并按照成绩降序排序:
```sql
SELECT student_id, score
FROM students
INNER JOIN courses ON students.course_id = courses.course_id
WHERE courses.course_number = 4
ORDER BY score DESC;
```
这个查询做了以下几件事:
1. `SELECT student_id, score`:选择需要显示的字段,即学生的学号(student_id)和成绩(score)。
2. `FROM students` 和 `INNER JOIN courses ON students.course_id = courses.course_id`:首先从学生表(students)开始,通过course_id字段与其他课程表(courses)做内连接,找到选修了4号课程的学生。
3. `WHERE courses.course_number = 4`:过滤出课程编号为4的课程。
4. `ORDER BY score DESC`:最后将结果按照成绩(score)字段值降序排列。
相关问题
1. 查询全体学生的学号和姓名 2. 查询全体学生的详细记录 3. 查询所有选修过课程的学生学号 4. 查询考试有不及格的学生学号 5. 查询考试有不及格的学生学号 查询不是信息系(IS)、计算机系(CS)的学生性别、年龄、系别 6. 查询选修了四号课的学生学号和成绩,结果按成绩降序排列 7. 查询每个课程号和相应的选课人数 8. 查询计算机系的学生姓名,年龄,系别 9. 查询年龄18-20岁的学生学号,姓名,年龄,系别 10. 查询姓刘的学生情况 11. 查询既选修1号课程,又选修2号课程的学生学号 12. 查询学生的姓名和出生年份 13. 查询没有成绩的学生的学号和课程号 14. 查询总成绩大于200分的学生学号 15. 查询每门课程不及格学生人数 16. 查询不及格课程超过三门的学生学号 17. 查询年龄在10到19岁之间的学生信息 18. 查询全体学生情况,按所在系升序排列 19. 查询选了1号课程的学生平均成绩 20. 查询选了3号课程的学生最高分 21. 查询每个同学的总成绩 用MySQL实现
很抱歉,我是一个语言模型AI,无法直接访问数据库。但我可以告诉你一些SQL语句,供你参考:
1. 查询全体学生的学号和姓名
SELECT 学号, 姓名 FROM 学生表;
2. 查询全体学生的详细记录
SELECT * FROM 学生表;
3. 查询所有选修过课程的学生学号
SELECT DISTINCT 学号 FROM 选课表;
4. 查询考试有不及格的学生学号
SELECT DISTINCT 学号 FROM 成绩表 WHERE 成绩 < 60;
5. 查询不是信息系(IS)、计算机系(CS)的学生性别、年龄、系别
SELECT 性别, 年龄, 系别 FROM 学生表 WHERE 系别 NOT IN ('IS', 'CS');
6. 查询选修了四号课的学生学号和成绩,结果按成绩降序排列
SELECT 学号, 成绩 FROM 成绩表 WHERE 课程号 = '4' ORDER BY 成绩 DESC;
7. 查询每个课程号和相应的选课人数
SELECT 课程号, COUNT(*) AS 选课人数 FROM 选课表 GROUP BY 课程号;
8. 查询计算机系的学生姓名,年龄,系别
SELECT 姓名, 年龄, 系别 FROM 学生表 WHERE 系别 = 'CS';
9. 查询年龄18-20岁的学生学号,姓名,年龄,系别
SELECT 学号, 姓名, 年龄, 系别 FROM 学生表 WHERE 年龄 BETWEEN 18 AND 20;
10. 查询姓刘的学生情况
SELECT * FROM 学生表 WHERE 姓名 LIKE '刘%';
11. 查询既选修1号课程,又选修2号课程的学生学号
SELECT 学号 FROM 选课表 WHERE 课程号 IN ('1', '2') GROUP BY 学号 HAVING COUNT(DISTINCT 课程号) = 2;
12. 查询学生的姓名和出生年份
SELECT 姓名, YEAR(出生日期) AS 出生年份 FROM 学生表;
13. 查询没有成绩的学生的学号和课程号
SELECT 学号, 课程号 FROM 选课表 WHERE NOT EXISTS (SELECT * FROM 成绩表 WHERE 选课表.学号 = 成绩表.学号 AND 选课表.课程号 = 成绩表.课程号);
14. 查询总成绩大于200分的学生学号
SELECT 学号 FROM 成绩表 GROUP BY 学号 HAVING SUM(成绩) > 200;
15. 查询每门课程不及格学生人数
SELECT 课程号, COUNT(*) AS 不及格人数 FROM 成绩表 WHERE 成绩 < 60 GROUP BY 课程号;
16. 查询不及格课程超过三门的学生学号
SELECT 学号 FROM 成绩表 WHERE 成绩 < 60 GROUP BY 学号 HAVING COUNT(*) > 3;
17. 查询年龄在10到19岁之间的学生信息
SELECT * FROM 学生表 WHERE 年龄 BETWEEN 10 AND 19;
18. 查询全体学生情况,按所在系升序排列
SELECT * FROM 学生表 ORDER BY 系别 ASC;
19. 查询选了1号课程的学生平均成绩
SELECT AVG(成绩) AS 平均成绩 FROM 成绩表 WHERE 课程号 = '1';
20. 查询选了3号课程的学生最高分
SELECT MAX(成绩) AS 最高分 FROM 成绩表 WHERE 课程号 = '3';
21. 查询每个同学的总成绩
SELECT 学号, SUM(成绩) AS 总成绩 FROM 成绩表 GROUP BY 学号;
MySQL以数据库user_db及数据表student、teacher、class、course、sc为基础(11)查询信息技术学院的必修课和限选课的数量及平均学分; (12)查询每名学生的选课数量及平均成绩,按照平均成绩降序排列; (13)查询各门课程编号、选课人数及其及格率; (14)查询选课人数前五名的课程; (15)查询选修课程数最多和最少的学生的学号及选课数; 2、SQL子查询的应用; (1)查询信息技术学院年龄最大的学生的学号、姓名、性别; (2)查询每个院系年龄最大的学生的学号、姓名、性别、院系及年龄; (3)查询和“崔晓”一个院系的其他学生的学号、姓名、院系; (4)查询平均成绩在60分以上的课程及其平均成绩; (5)查询平均成绩大于“高莉”的平均成绩的学生学号、姓名及平均成绩; (6)查询课程的学分高于全体课程平均学分的课程编号、名称、学分及所属院系,查询结果按照学分降序排列; (7)查询至少有一名学生选修的所有课程的课程号及课程名;
11. 查询信息技术学院的必修课和限选课的数量及平均学分:
```
SELECT
SUM(CASE WHEN course_type = '必修' THEN 1 ELSE 0 END) AS required_course_count,
SUM(CASE WHEN course_type = '限选' THEN 1 ELSE 0 END) AS elective_course_count,
AVG(CASE WHEN course_type IN ('必修', '限选') THEN credit END) AS avg_credit
FROM
class
WHERE
department = '信息技术学院';
```
12. 查询每名学生的选课数量及平均成绩,按照平均成绩降序排列:
```
SELECT
sc.student_id,
COUNT(*) AS course_count,
AVG(score) AS avg_score
FROM
sc
JOIN
student ON student.id = sc.student_id
GROUP BY
sc.student_id
ORDER BY
avg_score DESC;
```
13. 查询各门课程编号、选课人数及其及格率:
```
SELECT
course_id,
COUNT(*) AS student_count,
SUM(CASE WHEN score >= 60 THEN 1 ELSE 0 END) / COUNT(*) AS pass_rate
FROM
sc
GROUP BY
course_id;
```
14. 查询选课人数前五名的课程:
```
SELECT
course_id,
COUNT(*) AS student_count
FROM
sc
GROUP BY
course_id
ORDER BY
student_count DESC
LIMIT 5;
```
15. 查询选修课程数最多和最少的学生的学号及选课数:
```
SELECT
student_id,
COUNT(*) AS course_count
FROM
sc
GROUP BY
student_id
HAVING
COUNT(*) = (SELECT MAX(cnt) FROM (SELECT COUNT(*) AS cnt FROM sc GROUP BY student_id) AS t)
OR COUNT(*) = (SELECT MIN(cnt) FROM (SELECT COUNT(*) AS cnt FROM sc GROUP BY student_id) AS t);
```
1. SQL子查询的应用:
(1) 查询信息技术学院年龄最大的学生的学号、姓名、性别:
```
SELECT
id, name, gender
FROM
student
WHERE
department = '信息技术学院' AND age = (SELECT MAX(age) FROM student WHERE department = '信息技术学院');
```
(2) 查询每个院系年龄最大的学生的学号、姓名、性别、院系及年龄:
```
SELECT
s.id, s.name, s.gender, s.age, s.department
FROM
student s
JOIN
(SELECT department, MAX(age) AS max_age FROM student GROUP BY department) t
ON
s.department = t.department AND s.age = t.max_age;
```
(3) 查询和“崔晓”一个院系的其他学生的学号、姓名、院系:
```
SELECT
id, name, department
FROM
student
WHERE
department = (SELECT department FROM student WHERE name = '崔晓') AND name != '崔晓';
```
(4) 查询平均成绩在60分以上的课程及其平均成绩:
```
SELECT
course_id,
AVG(score) AS avg_score
FROM
sc
WHERE
course_id IN (SELECT course_id FROM sc GROUP BY course_id HAVING AVG(score) >= 60)
GROUP BY
course_id;
```
(5) 查询平均成绩大于“高莉”的平均成绩的学生学号、姓名及平均成绩:
```
SELECT
id, name, AVG(score) AS avg_score
FROM
student
JOIN
sc ON student.id = sc.student_id
WHERE
AVG(score) > (SELECT AVG(score) FROM student JOIN sc ON student.id = sc.student_id WHERE name = '高莉')
GROUP BY
id, name;
```
(6) 查询课程的学分高于全体课程平均学分的课程编号、名称、学分及所属院系,查询结果按照学分降序排列:
```
SELECT
course.id, course.name, course.credit, course.department
FROM
course
WHERE
credit > (SELECT AVG(credit) FROM course)
ORDER BY
credit DESC;
```
(7) 查询至少有一名学生选修的所有课程的课程号及课程名:
```
SELECT
id, name
FROM
course
WHERE
id IN (SELECT DISTINCT course_id FROM sc);
```
阅读全文