MySQL关联查询中如何使用分组和排序

avatar
作者
筋斗云
阅读量:1

在MySQL关联查询中,可以使用GROUP BY子句对查询结果进行分组,使用ORDER BY子句对分组后的结果进行排序。以下是一个示例:

假设有两个表,一个是学生表(student),一个是课程表(course),学生表中包含学生的ID和姓名,课程表中包含课程的ID和名称,两个表之间通过学生选课的关系表选课表(student_course)进行关联。

  1. 查询每个学生选修的课程数,并按选修的课程数降序排序:
SELECT s.student_id, s.student_name, COUNT(c.course_id) AS num_courses FROM student s LEFT JOIN student_course sc ON s.student_id = sc.student_id LEFT JOIN course c ON sc.course_id = c.course_id GROUP BY s.student_id, s.student_name ORDER BY num_courses DESC; 

在这个查询中,首先通过LEFT JOIN将学生表和选课表关联起来,然后再通过LEFT JOIN将选课表和课程表关联起来。然后使用GROUP BY子句按学生ID和姓名进行分组,使用COUNT函数统计每个学生选修的课程数。最后使用ORDER BY子句按选修的课程数降序排序。

  1. 查询每门课程的平均成绩,并按平均成绩升序排序:
SELECT c.course_id, c.course_name, AVG(sc.score) AS avg_score FROM course c LEFT JOIN student_course sc ON c.course_id = sc.course_id GROUP BY c.course_id, c.course_name ORDER BY avg_score ASC; 

在这个查询中,首先通过LEFT JOIN将课程表和选课表关联起来。然后使用GROUP BY子句按课程ID和名称进行分组,使用AVG函数计算每门课程的平均成绩。最后使用ORDER BY子句按平均成绩升序排序。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!