MySql 统计排名


例子:

SET @ranking=0;

select *,@ranking:=@ranking+1 AS `ranking` from table ORDER BY `members` DESC;

1. 先给用户变量 @ranking 赋值,mysql中用户变量以@开头,不用事先申明;

2. 然后按照某字段排序,返回字段中增加 如下代码:

@ranking:=@ranking+1

这样查询的结果中就包含 ranking 字段,表示当前排名。

遇到的问题:

    1. 执行语句提示语法错误,分开执行就不会出错。

    2. 数据分页

SET @ranking=当前第几页 * 每页数量;

  3. 某条记录的排名

SET @ranking=0;

select * from (select *,@ranking:=@ranking+1 AS `ranking` from table ORDER BY `members` DESC) as result where result.id = 17;

以上均为优化;



转载于:https://my.oschina.net/zhanyu/blog/464701

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值