iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >怎么用MySQL窗口函数实现榜单排名
  • 866
分享到

怎么用MySQL窗口函数实现榜单排名

2023-07-06 01:07:06 866人浏览 泡泡鱼
摘要

本篇内容主要讲解“怎么用MySQL窗口函数实现榜单排名”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用Mysql窗口函数实现榜单排名”吧!首先,先建一个测试表create tabl

本篇内容主要讲解“怎么用MySQL窗口函数实现榜单排名”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用Mysql窗口函数实现榜单排名”吧!

首先,先建一个测试

create table praise_record(    id bigint primary key auto_increment,    name varchar(10),    praise_num int) ENGINE=InnoDB;

然后让chatGpt给我们生成几条测试数据

INSERT INTO praise_record (name, praise_num) VALUES ('John', 5);INSERT INTO praise_record (name, praise_num) VALUES ('Jane', 3);INSERT INTO praise_record (name, praise_num) VALUES ('Bob', 10);INSERT INTO praise_record (name, praise_num) VALUES ('Alice', 3);INSERT INTO praise_record (name, praise_num) VALUES ('David', 7);INSERT INTO praise_record (name, praise_num) VALUES ('oct', 7);

然后就可以开始实现我们的需求:返回点赞的榜单,并返回排名

rank()

使用rank()函数返回点赞的榜单, rank() over()

## 注意这里返回的rank字段要用反引号包起来select name, praise_num, rank() over (order by praise_num desc) as `rank` from praise_record;+-------+------------+------+| name  | praise_num | rank |+-------+------------+------+| Bob   |         10 |    1 || David |          7 |    2 || oct   |          7 |    2 || John  |          5 |    4 || Jane  |          3 |    5 || Alice |          3 |    5 |+-------+------------+------+

可以看到使用rank()函数的时候相同的点赞数会返回相同的排名,排名会产生跳跃,最终的排名不是连续的

dense_rank()

使用dense_rank()函数返回点赞的榜单, dense_rank() over()

 select name, praise_num, dense_rank() over (order by praise_num desc) as `rank` from praise_record;  +-------+------------+------+| name  | praise_num | rank |+-------+------------+------+| Bob   |         10 |    1 || David |          7 |    2 || oct   |          7 |    2 || John  |          5 |    3 || Jane  |          3 |    4 || Alice |          3 |    4 |+-------+------------+------+

与rank()函数相同的是,相同点赞数会返回相同的排名,但是dense_rank()返回的最终排名是连续的排名

row_number()

row_number()函数返回点赞的榜单,row_number() over()

 select name, praise_num, row_number() over (order by praise_num desc) as `rank` from praise_record; +-------+------------+------+| name  | praise_num | rank |+-------+------------+------+| Bob   |         10 |    1 || David |          7 |    2 || oct   |          7 |    3 || John  |          5 |    4 || Jane  |          3 |    5 || Alice |          3 |    6 |+-------+------------+------+

row_number()函数适合当返回的列表只需要序号时使用

以上三个函数都是mysql8.0新加入的,所以在Mysql5.7这些老版本上我们可以模拟实现一下,顺便学习一下这三个窗口函数的实现原理

rank()函数的模拟实现

select p1.name, p1.praise_num, count(p2.praise_num) + 1 as `rank` from praise_record p1left join praise_record p2 on p1.praise_num < p2.praise_numgroup by p1.name, p1.praise_numorder by `rank`;+-------+------------+------+| name  | praise_num | rank |+-------+------------+------+| Bob   |         10 |    1 || David |          7 |    2 || oct   |          7 |    2 || John  |          5 |    4 || Jane  |          3 |    5 || Alice |          3 |    5 |+-------+------------+------+

我们可以使用自联接的方式将每个分数低于当前行分数的记录计数,最后将计数值加1作为当前行的排名,来模拟实现rank()

dense_rank()的模拟实现

select p1.name, p1.praise_num, count(distinct p2.praise_num) + 1 as `dense_rank` from praise_record p1left join praise_record p2 on p1.praise_num < p2.praise_numgroup by p1.name, p1.praise_numorder by `dense_rank`;+-------+------------+------------+| name  | praise_num | dense_rank |+-------+------------+------------+| Bob   |         10 |          1 || oct   |          7 |          2 || David |          7 |          2 || John  |          5 |          3 || Jane  |          3 |          4 || Alice |          3 |          4 |+-------+------------+------------+

dense_rank的实现与rank差不多,唯一的区别是增加了distinct对点赞数做了去重,这样子对不同的点赞数返回的排名就是连续的

row_number的模拟实现

##使用自定义变量得先初始化set @rowNum = 0;select name, praise_num, @rowNum := @rowNum +1 as `row_number`  from praise_record order by praise_num desc ;+-------+------------+------------+| name  | praise_num | row_number |+-------+------------+------------+| Bob   |         10 |          1 || David |          7 |          2 || oct   |          7 |          3 || John  |          5 |          4 || Jane  |          3 |          5 || Alice |          3 |          6 |+-------+------------+------------+

我们可以使用一个rowNum变量来记录行号,每一行的数据rowNUm都+1,这样子就可以得到我们想要的序号

到此,相信大家对“怎么用MySQL窗口函数实现榜单排名”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

您可能感兴趣的文档:

--结束END--

本文标题: 怎么用MySQL窗口函数实现榜单排名

本文链接: https://www.lsjlt.com/news/356922.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL窗口函数实现榜单排名
    目录rank()dense_rank()row_number()rank()函数的模拟实现dense_rank()的模拟实现row_number的模拟实现总结相信大家在日常的开发中经常会碰到榜单类的活动需求,通常在榜单中...
    99+
    2023-04-11
    MySQL 榜单排名 MySQL 排名
  • 怎么用MySQL窗口函数实现榜单排名
    本篇内容主要讲解“怎么用MySQL窗口函数实现榜单排名”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用MySQL窗口函数实现榜单排名”吧!首先,先建一个测试表create tabl...
    99+
    2023-07-06
  • SQL窗口函数之排名窗口函数怎么使用
    这篇文章主要介绍“SQL窗口函数之排名窗口函数怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“SQL窗口函数之排名窗口函数怎么使用”文章能帮助大家解决问题。取...
    99+
    2024-04-02
  • SQL窗口函数之排名窗口函数的使用
    目录案例分析案例使用的示例表1.环比分析2.同比分析3.复合增长率4.不同产品最高和最低销售额示例表和脚本关于窗口函数的基础,请看文章SQL窗口函数 取值窗口函数可以用于返回窗口内指...
    99+
    2024-04-02
  • MySQL查询排名的2种方式:变量排名、窗口函数
    如果你想在MySQL查询中进行排名,可以使用以下几种方法: 使用变量进行排名: 以下是一个基于分数对学生进行排名的示例: SET @rank = 0;SELECT @rank := @ran...
    99+
    2023-10-12
    mysql 数据库
  • 如何使用Pandas实现MySQL窗口函数
    今天小编给大家分享一下如何使用Pandas实现MySQL窗口函数的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、前言环境:...
    99+
    2023-07-05
  • MySQL 8.0窗口函数怎么运行
    今天就跟大家聊聊有关MySQL 8.0窗口函数怎么运行,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。# ROW_NUMBER() ...
    99+
    2024-04-02
  • 使用Pandas实现MySQL窗口函数的解决方法
    目录一、前言二、语法对比数据表row_number()lead()/lag()rank()/dense_rank()first_value()count()/sum()三、小结一、前...
    99+
    2023-02-22
    Pandas 窗口函数 Pandas mysql窗口函数
  • SQL窗口函数怎么使用
    本文小编为大家详细介绍“SQL窗口函数怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“SQL窗口函数怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。什么是窗口函数S...
    99+
    2024-04-02
  • 在CMD窗口中调用python函数的实现
    目录1.问题背景2.解决方案2.1.Python文件中只包含一个函数,而且不需要输入任何参数2.2.Python文件中有多个函数,调用其中某一个,并且输入参数1.问题背景 针对目前愈...
    99+
    2024-04-02
  • 使用redis怎么实现一个排行榜功能
    使用redis怎么实现一个排行榜功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。加入排行榜获取redis实例import redismain_rds...
    99+
    2023-06-15
  • 怎么使用QGraphicsView实现气泡聊天窗口+排雷功能
    这篇“怎么使用QGraphicsView实现气泡聊天窗口+排雷功能”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“怎么使用QG...
    99+
    2023-06-30
  • 怎么用C#实现MSN Messenger窗口
    这篇文章主要介绍“怎么用C#实现MSN Messenger窗口”,在日常操作中,相信很多人在怎么用C#实现MSN Messenger窗口问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用C#实现MSN Me...
    99+
    2023-06-17
  • 怎么用Python爬虫获取国外大桥排行榜数据清单
    这篇文章主要介绍“怎么用Python爬虫获取国外大桥排行榜数据清单”,在日常操作中,相信很多人在怎么用Python爬虫获取国外大桥排行榜数据清单问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用Python...
    99+
    2023-06-30
  • Java怎么模拟rank/over函数实现获取分组排名
    这篇“Java怎么模拟rank/over函数实现获取分组排名”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Java怎么模拟r...
    99+
    2023-07-06
  • C#中怎么利用排序函数实现冒泡排序
    今天就跟大家聊聊有关C#中怎么利用排序函数实现冒泡排序,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。所谓冒泡排序就是在每一次排序的过程中总有一个***的值被移动到后面,值小的就像水泡...
    99+
    2023-06-17
  • 怎么解决PostgreSQL窗口函数调用的限制
    这篇文章主要讲解了“怎么解决PostgreSQL窗口函数调用的限制”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么解决PostgreSQL窗口函数调用的限...
    99+
    2024-04-02
  • Sql Server和Access怎么实现数据排名
    这篇文章主要介绍“Sql Server和Access怎么实现数据排名”,在日常操作中,相信很多人在Sql Server和Access怎么实现数据排名问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方...
    99+
    2024-04-02
  • PHP中怎么利用sort()函数实现数组排序
    PHP中怎么利用sort()函数实现数组排序,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。一般数组中的各元素均以字符或数字表现的,所以可对数组元素进行升序排列,...
    99+
    2023-06-17
  • J2ME中clip窗口可使用anchor怎么实现
    这篇文章主要为大家展示了“J2ME中clip窗口可使用anchor怎么实现”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“J2ME中clip窗口可使用anchor怎么实现”这篇文章吧。      ...
    99+
    2023-06-03
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作