mysql 统计每门课程的选课人数、每门课程的最高分、最低分、平均分。
时间: 2023-06-26 14:10:21 浏览: 1838
可以使用以下 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_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` 关键字为聚合函数指定别名,使得查询结果的列名符合要求。
假设有学生-选课数据库,其中有学生表,课程表,教师表,选课表,其结构如下:学生(学号,姓名,专业,入学年份),课程(课程号,课程名,学分),选课(学号,课程号,成绩)。一门课程可以被多名学生选修,一名学生可以选修多门课程。 (1)为了提高各课程的及格率,在统计其成绩之前,将学生成绩分布于55-60之间的均修改为60,再录入学生档案中。(使用触发器完成) (2)对每个学生,统计其获得的最高成绩的课程号。(使用视图完成) (3)任意给定一门课程号,统计其成绩分布,如:最高分,最低分,平均分,各分数段人数;(使用存储过程完成)
好的,我来为您解答。针对您的问题,我分别回答如下:
1. 触发器实现学生成绩修改:
您可以使用如下的触发器来实现对学生成绩的修改:
```mysql
CREATE TRIGGER update_grade
BEFORE INSERT ON 选课
FOR EACH ROW
BEGIN
IF NEW.成绩 >= 55 AND NEW.成绩 < 60 THEN
SET NEW.成绩 = 60;
END IF;
END;
```
这个触发器会在每次插入选课表的数据前触发,如果学生成绩分布在55-60之间,会将其修改为60。
2. 视图统计每个学生获得的最高成绩:
您可以使用如下的视图来实现对每个学生最高成绩的统计:
```mysql
CREATE VIEW max_grade_view AS
SELECT s.学号, s.姓名, MAX(选课.成绩) AS 最高成绩, 选课.课程号
FROM 学生 s, 选课
WHERE s.学号 = 选课.学号
GROUP BY s.学号, 选课.课程号;
```
这个视图会对学生表和选课表进行联合查询,统计每个学生获得的最高成绩及对应的课程号。
3. 存储过程统计指定课程的成绩分布:
您可以使用如下的存储过程来实现对指定课程成绩分布的统计:
```mysql
CREATE PROCEDURE course_grade(IN course_id INT)
BEGIN
SELECT COUNT(*) AS 人数, MAX(成绩) AS 最高分, MIN(成绩) AS 最低分, AVG(成绩) AS 平均分,
CONCAT(FLOOR(成绩/10)*10, '-', FLOOR(成绩/10)*10 + 9) AS 分数段
FROM 选课
WHERE 课程号 = course_id
GROUP BY 分数段;
END;
```
这个存储过程会对选课表进行查询,统计指定课程的成绩分布,包括最高分、最低分、平均分、各分数段的人数等信息。
希望这些回答能够对您有所帮助!
阅读全文