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

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日

悬赏问题

  • ¥170 如图所示配置eNSP
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改
  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥15 键盘指令混乱情况下的启动盘系统重装