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

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

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

1.数据源

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

2.数据整体排名

1)普通排名

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

set @ rank=0;

挑选

城市,

得分,

@rank:=@rank 1rank

fromcs

orderbyscoredesc结果如下:

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

2)并列排名

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

设置@rank=0,@ price=null

选择。*,

casewhen @ price=scorethen @ rank

当@ price:=scorethen那么@rank:=@rank 1endrank

fromcsorderbyscoredesc

-当查询的得分值=@价格时,输出@rank,

-当不等时,将得分值赋给@价格,并输出@rank:=@rank 1

-或者

设置@rank=0,@ price=null

挑选

城市、分数、排名

(选择项。*,

@rank:=if(@p=score,@rank,@rank 1)rank,

@ p:=分数

fromcs

order by core desc)a;结果如下:

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

3)并列排名

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

set@rank=0,@price=null,@ z=1;

挑选

城市、分数、排名

(选择

cs .*,

@rank:=if(@p=score,@rank,@z)rank,

@ p:=分数,@z:=@z 1

fromcs

order by core desc)a;结果如下:

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

3.数据分组后组内排名

1)分组普通排名

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

set@rank=0,@ c=null

挑选

cs.city,cs.score,

@rank:=if(@c=city,@rank 1,1)rank,

@ c:=城市

fromcs

orderbycs.city,cs.score结果如下:

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

2)分组后并列排名

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

set@rank=0,@c=null,@ s=null

挑选

cs.city,cs.score,

@rank:=if(@c=city,if(@s=score,@rank,@rank 1),1)rank,

@ c:=城市,

@ s:=分数

fromcs

orderbycs.city,cs.score结果如下:

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

3)分组后并列排名

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

set@rank=0,@c=null,@ s=null

挑选

cs.city,cs.score,

@rank:=if(@c=city,if(@s=score,@rank,@rank 1),1)rank,

@ c:=城市,

@ s:=分数

fromcs

orderbycs.city,cs.score结果如下:

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

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

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

set@rank=0,@z=0,@c=null,@ s=null

selecta.city,a.score,a.rankfrom

(选择

cs.citycity,cs.scorescore,

@z:=if(@c=city,@z 1,1),

@rank:=if(@c=city,if(@s=score,@rank,@z),1)rank,

@ c:=城市,

@ s:=分数

fromcs

orderbycs.city,cs.scoredesc)a

哪里?秩=2;结果如下:

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

内部查询

从乡村基中选择*

哪里(

从列表中选择计数(*)项

其中c . city=cs。城市和c . scorcs。分数)2

按城市排序,分数描述结果如下:

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

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

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

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

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/60903.html

(0)

相关推荐

  • Thinkphp5.1怎么实现邮箱验证

    技术Thinkphp5.1怎么实现邮箱验证本篇内容介绍了“Thinkphp5.1怎么实现邮箱验证”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔

    攻略 2021年11月16日
  • php的结构函数是什么(php定义和函数有什么区别)

    技术php中system函数有什么用小编给大家分享一下php中system函数有什么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

    攻略 2021年12月19日
  • 怎样深入学习JVM堆与JVM栈

    技术怎样深入学习JVM堆与JVM栈今天就跟大家聊聊有关怎样深入学习JVM堆与JVM栈,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。JVM栈解决程序的运行问题,即程

    攻略 2021年10月23日
  • linux中find命令、正则表达式、三剑客之grep基本使用

    技术linux中find命令、正则表达式、三剑客之grep基本使用 linux中find命令、正则表达式、三剑客之grep基本使用一、find命令的基本使用find 命令主要用于查找目录和文件,可以指定

    礼包 2021年12月21日
  • 分析Java分布式系统原理

    技术分析Java分布式系统原理这篇文章主要讲解了“分析Java分布式系统原理”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“分析Java分布式系统原理”吧!1 概念1.1

    攻略 2021年11月5日
  • 将数据库遍历结果加入List集合中

    技术将数据库遍历结果加入List集合中 将数据库遍历结果加入List集合中package dao;import domain.User;
    import jdbcutil.util;import java

    礼包 2021年12月22日