mysql实现排行榜

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

下来我们进入正题。

前两天在给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或者存储过程来进行调用。

第一次写博文,望轻喷。

欢迎大家讨论。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值