MySql分组:组内取前*条数据
MySql分组:组内取前*条数据,例如:查询每关最先通关的15个玩家信息。
-- 获取分组,每组前*条,id字符串集合 SELECT GROUP_CONCAT( topPassMissionInfo SEPARATOR '--------------' ) FROM ( SELECT missionId, SUBSTRING_INDEX( GROUP_CONCAT( userId ORDER BY passTime DESC ), ',', 15 ) AS topPassMissionInfo FROM t_u_player_pass_mission GROUP BY missionId ) a
结果如下:
再根据userId字段的in条件去查询详细信息即可:SQL如下,因为group_concat函数获得的字符串,只会匹配第一个,之后 的就都不匹配了此时需要使用 FIND_IN_SET 函数,
SELECT * FROM t_u_table WHERE FIND_IN_SET( userId, ( SELECT GROUP_CONCAT( topPassMissionInfo SEPARATOR ',' ) FROM ( SELECT missionId, SUBSTRING_INDEX( GROUP_CONCAT( userId ORDER BY passTime DESC ), ',', 15 ) AS topPassMissionInfo FROM t_u_player_pass_mission GROUP BY missionId ) a ) );
如果主键是联合主键,不是单个字段(上例中为userId),可结合CONCAT函数使用
如下:联合主键为 missionId 和 userId
-- 最早通关 SELECT *FROM t_u_player_pass_mission WHERE FIND_IN_SET( CONCAT( missionId, "_", userId ), ( SELECT GROUP_CONCAT( topPassMissionInfo SEPARATOR ',' ) FROM ( SELECT missionId, SUBSTRING_INDEX( GROUP_CONCAT( CONCAT( missionId, "_", userId ) ORDER BY passTime ), ',', 15 ) AS topPassMissionInfo FROM t_u_player_pass_mission GROUP BY missionId ) a ) );
源码,是痛苦的,又是快乐的,如果没有这痛苦,也就没有了这快乐!
本文作者:好Wu赖
本文链接:https://www.cnblogs.com/erlongxizhu-03/p/16888447.html
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!