Tony_28 2022-08-18 15:13 采纳率: 100%
浏览 944
已结题

MYSQL关于 group by分组后只取每组的前三条数据

关于MYSQL分组查询问题,
只查询同一个表table 以表中字段sid进行group by 分组
然后获取每个分组中的前三条数据
得出以下代码

SELECT a.* FROM table a GROUP BY a.sid
union all
SELECT a.* FROM table a WHERE a.id NOT IN (SELECT GROUP_CONCAT(b.id) FROM table b GROUP BY b.sid) GROUP BY a.sid
union all
SELECT a.* FROM table a WHERE a.id NOT IN (
SELECT GROUP_CONCAT(b.id) FROM table b WHERE b.id NOT IN (
SELECT GROUP_CONCAT(c.id) FROM table c GROUP BY c.sid
) GROUP BY b.sid
) GROUP BY a.sid
ORDER BY sid ASC

但MYSQL运行不起来这种套娃的代码。。
请问有什么其他最优解法吗?

  • 写回答

1条回答 默认 最新

  • honestman_ 2022-08-18 15:39
    关注

    假如取前三条的标准为分数最高的三条,分数字段为score, SQL如下:
    select * from table a where (select count(1) from table where sid=a.sid and score>=a.score)<=3

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 8月26日
  • 已采纳回答 8月18日
  • 创建了问题 8月18日