您的位置:首页 > 数据库 > MySQL

MySQL 查询排名

2017-04-06 15:53 337 查看
参考:http://fellowtuts.com/mysql/query-to-obtain-rank-function-in-mysql

 

前段时间看到个帖子,是关于用 SQL 查询排名的。
那个帖子里针对的数据库是 Oracle,用到了 Oracle 自带的函数 RANK(或 DENSE_RANK)。
由于 MySQL 里没有相应的类似函数,所以写 SQL 会稍微繁琐一点。

参考文章的主要思路:

对目标列排序

设置一个变量作为排名值,在每条记录中自增 1

方案一

SQL: (如果想要降序排名,可以改成 ORDER BY age DESC)



效果:(值相同,排名不同)



 
方案二

SQL: (
暂存上一条记录的 age (@prevRank)。
> 如果当前 age 与其相等,使用与前一记录相同的排名;
> 否则排名加一,并更新 @prevRank
)



效果:(值相同,排名也相同;排名值连续递增)



方案三

SQL: (
增加一个变量(@incRank)用于记录序号(类似方案一)。
> 如果当前 age 与上一条记录相同,使用与前一记录相同的排名(类似方案二)
> 否则使用序号(@incRank)




效果:(值相同,排名也相同;排名值递增不连续)



 
 
附数据:



 





大小: 6.6 KB





大小: 10.9 KB





大小: 7.5 KB





大小: 10.7 KB





大小: 9 KB





大小: 8.2 KB





大小: 17.2 KB

查看图片附件
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: