SQL语句--mysql排名、分组后组内排名、取各组的前几名

13 篇文章 3 订阅

数据:

一、整体排名(3种)

-- 普通排名:从1开始,顺序往下排

set @rank =0;
select city ,score, @rank := @rank+1 rank 
 from cs order by score desc;

-- 并列排名:相同的值是相同的排名,不用占空位

set @rank=0,@price=null;
select cs.* ,
 case when @price = score then @rank 
 when @price := score then @rank := @rank+1 end rank  
 from cs order by score desc;
 -- 当查询的score 值 = @price时,输出@rank,
 -- 当不等时,将score值赋给@price ,并输出@rank := @rank+1

-- 或者
set @rank=0,@price=null;
select a.city,a.score,a.rank from 
(select cs.*,
@rank := if(@p=score,@rank,@rank+1) rank,
@p := score
from cs order by score desc) a;

-- 并列排名:相同的值是相同的排名,需要占空位

set @rank=0,@price=null, @z=1;
select a.city,a.score,a.rank from 
(select cs.*,
@rank := if(@p=score,@rank,@z) rank,
@p := score,@z :=@z+1
from cs order by score desc) a;

二、分组后组内排名(3种)

-- 分组普通排名:顺序排名

set @rank=0,@c=null;
select cs.city,cs.score,
@rank := if(@c = city,@rank+1,1) rank,
@c := city
from cs order by cs.city,cs.score;

-- 组内并列排名:相同的值是相同的排名,不需要占空位

set @rank=0,@c=null,@s=null;
select cs.city,cs.score,
@rank := if(@c=city,if(@s=score,@rank,@rank+1),1) rank ,
@c := city,@s :=score 
from cs order by cs.city,cs.score;

-- 组内并列排名:相同的值是相同的排名,需要占空位

set @rank=0,@z=0,@c=null,@s=null;
select cs.city,cs.score,
@z := if(@c=city,@z+1,1),
@rank := if(@c=city,if(@s=score,@rank,@z),1) rank,
@c := city,@s :=score 
from cs order by cs.city,cs.score;

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

-- 方法1:按照分组排名的三种方式,然后限定排名的值

set @rank=0,@z=0,@c=null,@s=null;
select a.city,a.score,a.rank from 
(select cs.city city,cs.score score,
@z := if(@c=city,@z+1,1),
@rank := if(@c=city,if(@s=score,@rank,@z),1) rank,
@c := city,@s :=score 
from cs order by cs.city,cs.score desc) a
where a.rank<=2;

-- 方法2:内部查询

SELECT * FROM cs c
WHERE (
    SELECT count(*) FROM cs
    WHERE c.city=cs.city AND c.score<cs.score )<2
  ORDER BY city,score DESC;

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值