在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
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 := score from 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+1 from 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 := city from 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) a where a.rank<=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; 结果如下: 上述代码的执行原理如下图: 以上就是Mysql教程分组排名实现示例详解的详细内容,更多关于Mysql分组排名的资料请关注极客世界其它相关文章! |
请发表评论