MySQL 排名、分组后组内排名、取各组的前几名
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySQL 排名、分组后组内排名、取各组的前几名,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1515字,纯文字阅读大概需要3分钟。
内容图文
转载:https://www.cnblogs.com/niniya/p/9046449.html
一、排名
/*普通排名:从1开始,顺序往下排*/ SELECT cs.*,@r :=@r + 1 AS rank FROM cs,(SELECT @r := 0) r ORDER BY score;
/*并列排名:相同的值是相同的排名*/ SELECT cs.* , CASE WHEN @p=score THEN @r WHEN @p:=score THEN @r:=@r+1 END rank FROM cs,(SELECT @r:=0,@p:=NULL)r ORDER BY score;
/*并列排名:相同的值名次相同,与上例中的并列排名不同*/ SELECT city,score,rank FROM ( SELECT cs.*, @c:=IF(@p=score,@c,@r) AS rank, @p:=score, @r:=@r+1 FROM cs ,(SELECT @p:=NULL,@r:=1,@c:=0)r ORDER BY score )c
二、分组后组内排名
/*分组普通排名:顺序排名*/ SELECT city,score,rank FROM ( SELECT cs.*,IF(@p=city,@r:=@r+1,@r:=1) AS rank, @p:=city FROM cs,(SELECT @p:=NULL,@r:=0)r ORDER BY city,score )s;
/* 分组后并列排名:组内相同数值排名相同*/ SELECT city,score,rank FROM ( SELECT *, IF(@p=city, CASE WHEN @s=score THEN @r WHEN @s:=score THEN @r:=@r+1 END, @r:=1 ) AS rank, @p:=city, @s:=score FROM cs,(SELECT @p:=NULL,@s:=NULL,@r:=0)r ORDER BY city,score )s;
三、分组后取各组的前两名
/*取每组分数高的前两个,法一*/ SELECT city,score,rank FROM ( SELECT *, IF(@p=city, CASE WHEN @s=score THEN @r WHEN @s:=score THEN @r:=@r+1 END, @r:=1 ) AS rank, @p:=city, @s:=score FROM cs,(SELECT @p:=NULL,@s:=NULL,@r:=0)r ORDER BY city,score DESC )s WHERE rank <3;
/*分组后取前两个,法二*/ SELECT * FROM cs c WHERE ( SELECT count(*) FROM cs WHERE city=c.city AND score>c.score )<2 ORDER BY city,score DESC
参考:
https://www.jianshu.com/p/bb1b72a1623e
http://blog.sina.com.cn/s/blog_4c197d420101e408.html
内容总结
以上是互联网集市为您收集整理的MySQL 排名、分组后组内排名、取各组的前几名全部内容,希望文章能够帮你解决MySQL 排名、分组后组内排名、取各组的前几名所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。