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

下来我们进入正题。

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

第一次写博文,望轻喷。

欢迎大家讨论。

mysql制作排行榜_mysql实现排行榜相关推荐

  1. mysql 查排行榜_mysql 查询排行榜

    总结下mysql的排行榜查询,mysql 8 可以使用窗口函数,8以前就不行了.需求大概是一个游戏,用户可以玩多次,排名的时候取最高分排名 首先搞点测试数据 CREATE TABLE `t_game` ...

  2. mysql游戏名称_MySQL 游戏排行榜

    今天在坛子上看到了,顺便写下来. 有两种方法: 1.效率不高,因为有子查询.但是简洁.而且我对SOCRES表做了INDEX.所以性能上也差不了多少. mysql> show create tab ...

  3. mysql制作搜索引擎_MySQL 实现一个简单版搜索引擎,真是绝了!

    MySQL 实现一个简单版搜索引擎,真是绝了! 前言只有Innodb和myisam存储引擎能用全文索引(innodb支持全文索引是从mysql5.6开始的) char.varchar.text类型字段 ...

  4. mysql 汉编码 的选_peewee连接mysql汉语言数据编码_mysql

    peewee连接mysql中文数据编码 系统是win7 x64 python 2.7.6的site.py里面编码设定为 utf-8 py文件首行指定 #coding:utf-8 mysql 5.5.3 ...

  5. windows 新建mysql权限设置_Windows下设置MySQL安全权限_mysql

    注意:本文的内容涉及到修改NTFS磁盘权限和设置安全策略,请务必在确认您了解操作可能的后果之后再动手进行任何的修改. 文中提及的权限都是在原有权限上附加的权限. [修改步骤] 1.创建用户 创建一个名 ...

  6. mysql函数大全最小,MySQL函数一览_MySQL函数全部汇总

    前言 MySQL提供了众多功能强大.方便易用的函数,使用这些函数,可以极大地提高用户对于数据库的管理效率,从而更加灵活地满足不同用户的需求.本文将MySQL的函数分类并汇总,以便以后用到的时候可以随时 ...

  7. PHP+Mysql制作一个学生成绩查询模块

    PHP+Mysql制作一个学生成绩查询模块 我不是学PHP的我只是需要用一下PHP要是学又得好长时间,最好的方法就是问,但是问会的,又说让百度,得,我直接自己干吧,便花费了我一整天时间做了一下,从网上 ...

  8. 基于jquery+php+mysql 制作 仿google日历记事

    转载:基于jquery+php+mysql 制作 仿google日历记事 download: 本帖隐藏的内容  仿google日历记事.zip (33.55 KB, 下载次数: 0) 原帖地址:htt ...

  9. PHP+MySQL制作留言板

    ** PHP+MySQL制作留言板 ** 需要修改/include/config.php $db->dbbase = 'mb';$db->dbUser = 'root';$db->d ...

最新文章

  1. Facebook收购GrokStyle:布局AI零售
  2. CTP综合交易平台-开发后感
  3. 阿里巴巴分布式服务框架 Dubbo 团队成员梁飞专访
  4. linux中计算高斯的进程,linux下运行高斯比windows的优势
  5. 五、开始Github和码云之旅,新手如何上路
  6. 史上四大“杀人”建筑,烧掉几百亿,却犯低级错误,网友:有钱人的智商,我不懂
  7. 关于动态生成div的认识
  8. java装箱_Java 装箱 拆箱
  9. 基于Nginx的Wesocket负载均衡
  10. python将txt读入矩阵_python读入txt数据,并转成矩阵
  11. led同步回显到计算机屏幕,手把手教您如何将笔记本电脑的画面投屏到LED大屏幕上显示,音视频同步传输...
  12. 以太网交换机如何工作以及MAC和PHY
  13. python求高阶导数_高阶导数 - 问答 - Python中文网
  14. Facebook广告投放有哪些比较好的策略?
  15. canvas手写签名
  16. PaddleHub一键视频动漫化
  17. 大疆M210 V2+妙算2-G+LIVOX MID-40使用记录
  18. 锐捷S6248三层交换机syslog配置
  19. tbc新服务器消息,TBC最新消息泄露:将分为4个阶段,详细内容分析
  20. G1的mixed gc详细过程

热门文章

  1. java se 14 虚拟机规范
  2. APAD 7'“谷歌Android操作系统1.5无线触摸屏
  3. 电子商务系统怎么开发,有哪些流程_OctShop
  4. 产品经理与用户体验研究的关系
  5. 计算机职称照图片,全国职称计算机报名如何上传照片。怎么提示你无需上传照片。可以直接进行报名呢...
  6. 【牛客网华为机试】HJ89 24点运算
  7. STG游戏中瞄具的基本原理
  8. (转)对冲基金:AQR合伙人:“沉闷”股票回报更好
  9. 电脑开机密码忘记了怎么办
  10. BigBrother的大数据之旅Day 15 sqoop