数据库 
首页 > 数据库 > 浏览文章

详解MySQL分组排序求Top N

(编辑:jimmy 日期: 2024/11/16 浏览:3 次 )

MySQL分组排序求Top N

表结构

 详解MySQL分组排序求Top N

按照grp分组,按照num排序,每组取Top 3,输出结果如下:


 
 详解MySQL分组排序求Top N

源代码:

SELECT * FROM score AS t3  
WHERE (  
  SELECT COUNT(*) FROM score AS t1  
  LEFT JOIN score AS t2  
  ON t1.grp = t2.grp AND t1.num < t2.num  
  WHERE t1.id = t3.id 
) < 3 
ORDER BY t3.grp ASC, num DESC 
 

在where中可以通过子查询创造一个新的变量来过滤。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

上一篇:centos 6.9安装mysql的详细教程
下一篇:项目从MYSQL迁移至MARIADB教程
一句话新闻
微软与英特尔等合作伙伴联合定义“AI PC”:键盘需配有Copilot物理按键
几个月来,英特尔、微软、AMD和其它厂商都在共同推动“AI PC”的想法,朝着更多的AI功能迈进。在近日,英特尔在台北举行的开发者活动中,也宣布了关于AI PC加速计划、新的PC开发者计划和独立硬件供应商计划。
在此次发布会上,英特尔还发布了全新的全新的酷睿Ultra Meteor Lake NUC开发套件,以及联合微软等合作伙伴联合定义“AI PC”的定义标准。