首页 > 数据库技术 > 详细

MySQL 查询排名

时间:2015-05-23 02:12:30      阅读:8112      评论:0      收藏:0      [点我收藏+]

参考: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

bubuko.com,布布扣


效果:(值相同,排名不同)
bubuko.com,布布扣

?

方案二

SQL: (

暂存上一条记录的 age (@prevRank)。

> 如果当前 age 与其相等,使用与前一记录相同的排名;

> 否则排名加一,并更新 @prevRank

)


bubuko.com,布布扣


效果:(值相同,排名也相同;排名值连续递增)
bubuko.com,布布扣

方案三

SQL: (

增加一个变量(@incRank)用于记录序号(类似方案一)。

> 如果当前 age 与上一条记录相同,使用与前一记录相同的排名(类似方案二)

> 否则使用序号(@incRank)


bubuko.com,布布扣

效果:(值相同,排名也相同;排名值递增不连续)
bubuko.com,布布扣

?

?

附数据:


bubuko.com,布布扣
?

MySQL 查询排名

原文:http://pre.iteye.com/blog/2213487

(1)
(6)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!