可以使用子查询和LIMIT来实现先分组再取分组中的前10条记录。
例如,假设有一个表格students,其中包含学生姓名和成绩两列,要查询每个科目成绩最高的前3名学生:
SELECT *
FROM (
SELECT *
FROM students
ORDER BY score DESC
) AS sorted_scores
GROUP BY subject
LIMIT 3;
这里首先在子查询中按照成绩从高到低排序,然后将结果按照科目分组,并且只选取每个分组中的前三条记录。注意,在MySQL中使用GROUP BY时必须同时指定聚合函数或者其他表达式,否则会出现不确定性的错误结果。