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)

相关推荐

  • Maven编译打包时如何忽略测试用例

    技术Maven编译打包时如何忽略测试用例本篇文章给大家分享的是有关Maven编译打包时如何忽略测试用例,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。跳过测试

    攻略 2021年10月29日
  • 1元涨1000粉丝软件,抖音如何刷粉丝?

    技术1元涨1000粉丝软件,抖音如何刷粉丝?1元涨1000粉丝软件,抖音如何刷粉丝?身边玩抖音的朋友是越来越多,也就意味着抖音用户大军正在日渐壮大。抖音用户多,自然来网站咨询购买抖音粉丝的朋友就多。抖音粉丝少当然得想点办

    测评 2021年11月11日
  • Viper FTP怎么用

    技术Viper FTP怎么用今天就跟大家聊聊有关Viper FTP怎么用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Viper FTP是一款Mac平台上功能强大

    攻略 2021年11月20日
  • 如何进行MySQL5.6 二进制部署

    技术如何进行MySQL5.6 二进制部署这篇文章给大家介绍如何进行MySQL5.6 二进制部署,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。下载mysql并检查MD5[root@hadoop-01

    攻略 2021年10月25日
  • Redis要比Memcached更火的原因有哪些

    技术Redis要比Memcached更火的原因有哪些本篇内容介绍了“Redis要比Memcached更火的原因有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这

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

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

    礼包 2021年12月21日