mysql分组后取前几组_MySQL 排名、分组后组内排名、取各组的前几名

转载: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;

0eb6beeceaa3d2ca9589e5147aebd752.png

48304ba5e6f9fe08f3fa1abda7d326ab.png

/*并列排名:相同的值是相同的排名*/

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;

48304ba5e6f9fe08f3fa1abda7d326ab.png

2db687e5ca502dc94f58719065cc8028.png

48304ba5e6f9fe08f3fa1abda7d326ab.png

/*并列排名:相同的值名次相同,与上例中的并列排名不同*/

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

48304ba5e6f9fe08f3fa1abda7d326ab.png

50b3048485bffa44beb2cc20c91ad0e9.png

二、分组后组内排名

48304ba5e6f9fe08f3fa1abda7d326ab.png

/*分组普通排名:顺序排名*/

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;

48304ba5e6f9fe08f3fa1abda7d326ab.png

58bf9ef43f8d868f3c486071aced2cb7.png

48304ba5e6f9fe08f3fa1abda7d326ab.png

/* 分组后并列排名:组内相同数值排名相同*/

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;

48304ba5e6f9fe08f3fa1abda7d326ab.png

8150868e2005549399bacd2dfccb1c16.png

三、分组后取各组的前两名

48304ba5e6f9fe08f3fa1abda7d326ab.png

/*取每组分数高的前两个,法一*/

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;

48304ba5e6f9fe08f3fa1abda7d326ab.png

56302f65cdd83646aea403fa3daa5686.png

/*分组后取前两个,法二*/

SELECT * FROM cs c

WHERE (

SELECT count(*) FROM cs

WHERE city=c.city AND score>c.score )<2

ORDER BY city,score DESC

03c934da3709c81fc000660d172a03af.png

参考:

https://www.jianshu.com/p/bb1b72a1623e

http://blog.sina.com.cn/s/blog_4c197d420101e408.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值