Mysql教程分组排名实现示例详解

2022-05-15 0 199
目录
  • 1.数据源
  • 2.数据整体排名
    • 1)普通排名
    • 2)并列排名
    • 3)并列排名
  • 3.数据分组后组内排名
    • 1)分组普通排名
    • 2)分组后并列排名
    • 3)分组后并列排名
  • 4.分组后取各组的前两名

    1.数据源

    Mysql教程分组排名实现示例详解

    2.数据整体排名

    1)普通排名

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

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

    结果如下:

    Mysql教程分组排名实现示例详解

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

    结果如下:

    Mysql教程分组排名实现示例详解

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

    结果如下:

    Mysql教程分组排名实现示例详解

    3.数据分组后组内排名

    1)分组普通排名

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

    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;
    

    结果如下:

    Mysql教程分组排名实现示例详解

    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;
    

    结果如下:

    Mysql教程分组排名实现示例详解

    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;
    

    结果如下:

    Mysql教程分组排名实现示例详解

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

    结果如下:

    Mysql教程分组排名实现示例详解

    ② 内部查询

    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;
    

    结果如下:

    Mysql教程分组排名实现示例详解

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

    Mysql教程分组排名实现示例详解

    以上就是Mysql教程分组排名实现示例详解的详细内容,更多关于Mysql分组排名的资料请关注NICE源码其它相关文章!

    免责声明:
    1、本网站所有发布的源码、软件和资料均为收集各大资源网站整理而来;仅限用于学习和研究目的,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。 不得使用于非法商业用途,不得违反国家法律。否则后果自负!

    2、本站信息来自网络,版权争议与本站无关。一切关于该资源商业行为与www.niceym.com无关。
    如果您喜欢该程序,请支持正版源码、软件,购买注册,得到更好的正版服务。
    如有侵犯你版权的,请邮件与我们联系处理(邮箱:skknet@qq.com),本站将立即改正。

    NICE源码网 MySql Mysql教程分组排名实现示例详解 https://www.niceym.com/35174.html