mysql制作排行榜_mysql实现排行榜

博主分享了如何在MySQL中实现排行榜功能,特别是中国式的排行榜。文章介绍了三种类型的排行榜,并提供了核心SQL代码,通过变量和IF判断实现排名逻辑。内容适合对数据库排名操作感兴趣的读者。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

博主新人一枚,大家可以提出自己的宝贵意见。

下来我们进入正题。

前两天在给app写接口时,需要实现一个排行榜的业务。当然我们首先要了解排行榜的业务需求是什么,其次才是接口实现,不能像我一样,走了不少的弯路。

大家首先要了解接口的场景,再就是排行榜的规则,我们这里说的中国式排行榜。

排行榜总结了一下分为3种:

中国式排行:         非中国式排行1:              非中国式排行2:

1;                                   1;                                        1;

2;                                   2;                                        2;

2;                                   2;                                        3;

3;                                   4;                                        4;

3;                                   5;                                        5;

4;                                   5;                                        6;

5;                                   7;                                        7;

SELECT

user_id,

@position :=

IF (

@previous = good_bad_num,

@position,

@position + 1

) AS position ,@previous := good_bad_num

FROM

(

SELECT

user_id,

good_bad_num

FROM

v_praise_user

where office_id = everyoffice

ORDER BY

good_bad_num DESC

) d,

(

SELECT

@previous := - 1,

@position := 0

) AS s

其实SQL原理很简单,做过jsp页面的合并表格的都清楚,定义两个变量,一个控制状态,另一个进行业务。

SELECT

user_id,

good_bad_num

FROM

v_praise_user

where office_id = everyoffice

ORDER BY

good_bad_num DESC

这段主要是对v_praise_user表的good_bad_num 倒序排列,获取结果集。

SELECT

@previous := - 1,

@position := 0

必要需要的初始化,如果不经心初始化,初次查询会出现错误。

IF (

@previous = good_bad_num,

@position,

@position + 1

)

这段sql是这个排序的核心,一个IF判断语句,结合变量使用,实现排行业务。

@定义用户变量,只能在mysql数据库端执行,所以需要在数据库端用function或者存储过程来进行调用。

第一次写博文,望轻喷。

欢迎大家讨论。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值