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
查看图片附件
前段时间看到个帖子,是关于用 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
查看图片附件
相关文章推荐
- 为 MySQL 的查询结果添加排名字段
- MySql查询排名信息
- mysql:查询排名
- mysql查询排名的方法(yii的写法)
- mysql查询成绩排名显示-两种排名方式
- 在MYSQL中 如何查询排名数
- 【MySQL技巧】说一说MySQL中的查询排名
- mysql排名(查询篇)
- mysql select 语句查询排名
- MySql查询排名
- mysql查询排名
- MySQL中给自定义的字段查询结果添加排名的方法
- mysql 查询结果增加自动递增的一列,排名,排序
- Mysql 排名查询
- mysql 查询获取排名的方法(绝对有效)
- MYSQL查询语句:根据成绩更新全部排名
- 为 MySQL 的查询结果添加排名字段
- Mysql 查询实现成绩排名,相同分数名次相同,类似于rank()函数
- 在MySQL中查询某条数据的排名
- MySQL查询排名