用MySQL查询选课表中各门课的课程号,最高分,最低分和平均分,查询结果各列的列名分别为课程号,最高分,最低分和平均分。
时间: 2024-03-03 12:53:43 浏览: 34
可以使用如下的SQL语句进行查询:
```
SELECT course_id, MAX(score) AS highest_score, MIN(score) AS lowest_score, AVG(score) AS average_score
FROM course_selection
GROUP BY course_id;
```
其中,`course_selection` 表为选课表,包含了学生的选课信息,包括课程号 `course_id` 和分数 `score`。使用 `GROUP BY` 语句按照课程号分组,然后使用聚合函数 `MAX`、`MIN` 和 `AVG` 计算每门课的最高分、最低分和平均分。最后,使用 `AS` 关键字为聚合函数指定别名,使得查询结果的列名符合要求。
相关问题
mysql 统计每门课程的选课人数、每门课程的最高分、最低分、平均分。
可以使用以下 SQL 语句实现:
```
SELECT
course_name,
COUNT(DISTINCT student_id) AS num_students,
MAX(score) AS max_score,
MIN(score) AS min_score,
AVG(score) AS avg_score
FROM
course_score
INNER JOIN courses ON course_score.course_id = courses.course_id
GROUP BY
course_name;
```
其中,`course_score` 表是存储了每个学生在每门课程上的成绩信息的表,`courses` 表是存储了每门课程的基本信息的表。这个 SQL 语句会将两个表联结起来,并且按照课程名称分组,统计每门课程的选课人数、最高分、最低分和平均分。最终结果会以课程名称为行,各个统计指标为列的形式呈现。
mysql 查询每门课程的最高分和最低分
可以使用以下 SQL 语句来查询每门课程的最高分和最低分:
```
SELECT course_name, MAX(score) AS max_score, MIN(score) AS min_score
FROM scores
GROUP BY course_name;
```
其中,`scores` 是包含了课程名和分数的表,包括以下列:`course_name` 和 `score`。`MAX()` 函数返回每门课程的最高分,`MIN()` 函数返回每门课程的最低分。`GROUP BY` 子句将结果按照课程名进行分组。