ZBLOG

mysql 查询先分组再取分组中的前10

可以使用子查询和LIMIT来实现先分组再取分组中的前10条记录。

例如,假设有一个表格students,其中包含学生姓名和成绩两列,要查询每个科目成绩最高的前3名学生:

SELECT *
FROM (
  SELECT *
  FROM students
  ORDER BY score DESC
) AS sorted_scores
GROUP BY subject
LIMIT 3;

这里首先在子查询中按照成绩从高到低排序,然后将结果按照科目分组,并且只选取每个分组中的前三条记录。注意,在MySQL中使用GROUP BY时必须同时指定聚合函数或者其他表达式,否则会出现不确定性的错误结果。

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=4884

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?