千家信息网

Mysql数据分组排名实现的示例分析

发表于:2025-01-17 作者:千家信息网编辑
千家信息网最后更新 2025年01月17日,Mysql数据分组排名实现的示例分析,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1.数据源2.数据整体排名1)普通排名
千家信息网最后更新 2025年01月17日Mysql数据分组排名实现的示例分析

Mysql数据分组排名实现的示例分析,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

    1.数据源

    2.数据整体排名

    1)普通排名

    从1开始,按照顺序一次往下排(相同的值也是不同的排名)。

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

    结果如下:

    2)并列排名

    相同的值是相同的排名(但是不留空位)。

    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 := scorefrom cs order by score desc) a;

    结果如下:

    3)并列排名

    相同的值是相同的排名(但是留空位)。

    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+1from cs order by score desc) a;

    结果如下:

    3.数据分组后组内排名

    1)分组普通排名

    从1开始,按照顺序一次往下排(相同的值也是不同的排名)。

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

    结果如下:

    2)分组后并列排名

    组内相同数值排名相同,不占空位。

    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;

    结果如下:

    3)分组后并列排名

    组内相同数值排名相同,需要占空位。

    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;

    结果如下:

    4.分组后取各组的前两名

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

    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) awhere a.rank<=2;

    结果如下:

    ② 内部查询

    SELECT * FROM cs cWHERE (    SELECT count(*) FROM cs    WHERE c.city=cs.city AND c.score

    结果如下:

    上述代码的执行原理如下图:

    看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注行业资讯频道,感谢您对的支持。

    0