博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql @value := 用法
阅读量:7005 次
发布时间:2019-06-27

本文共 1196 字,大约阅读时间需要 3 分钟。

背景

有这么一张表,记录名字和分数,现在需要按照成绩排名,存在并列名次的情况

 

解决方法

思路:按照score从大到小排序,第一行数据就是第一名,第二行就是第二名......需要判断当前行的score和上一行的score的大小用来区分是否排名

 

先看解决代码:

SELECT name,scoreCASEWHEN @preScore = score THEN @curRank WHEN @preScore := score THEN @curRank:=@curRank +1END AS `Rank` FROM score,(SELECT @curRank := 0 AS curRank, @preScore := NULL AS preRank) i WHERE sex=1 ORDER BY score DESC

 

 

细节说明

 @preScore 这种是变量声明,类似之前的set ,set @a = 1;

:=  赋值,@preScore := 1,表示给@preScore赋值为1;

(SELECT @curRank := 0 AS curRank, @preScore := NULL AS preRank) i 单独派生出一个表,记得要加别名,不然会包如下的错误
Every derived table must have its own alias -- 派生出来的表都要有一个别名

  新增两列的表,一列是当前排名curRank,一个是上条记录的score值preScore,赋予默认值,curRank=0,preScore=null;

下面的操作类似linux中的awk操作

1. 按照score倒序排列,即score最大的一行,第一名的一条记录;

2. 先判断@preScore是否跟当前查询出来的score一致,因为默认@preScore为null,那不一致,不执行THEN后面的;

3. 进入到第二个WHEN,THEN中

4. 将当前查询出来的score=99赋值给@preScore,没有判断条件直接进入到THEN,@curRank=0+1,为1

5. 将@curRank 写为别名Rank=1

6. 第二条记录扫描

7. 先判断@preScore(此时为99)跟第二条记录的score(此时为89)对比,不相等,不执行THEN后面的数据;

8. 将当前查询出来的score=89赋值给@preScore,没有判断条件直接进入到THEN,@curRank=1+1,为2

9. 将@curRank 写为别名Rank=1

......

扫描完所有的记录后得到上表

case函数只返回第一个符合条件的值,剩下的case部分将会被自动忽略。

当有score一样的情况时,@preScore=score时,@curRank并没有做+1操作,所以就有了并列的情况

 

虽千万人,吾往矣!

转载地址:http://yoytl.baihongyu.com/

你可能感兴趣的文章
SharePoint 搜索爬网第三方网站配置
查看>>
总结Movie示例知识点
查看>>
WebUI无阻塞更新的实现
查看>>
协议森林12 天下为公 (TCP堵塞控制)
查看>>
尝试在C++里实现 Java 的 synchronized 关键字
查看>>
POJ-2057 The Lost House 贪心在动态规划中的应用
查看>>
uva10970 Big Chocolate
查看>>
PhoneGap API帮助文档翻译Notification提醒
查看>>
LESS介绍及其与Sass的差异
查看>>
PForDelta索引压缩算法的实现
查看>>
SQL调优:带函数的谓词导致CBO Cardinality计算误差
查看>>
正则表达式最后加一个/g或者/ig代表什么意思
查看>>
ASP.NET Dynamic Data Part.1(创建动态数据应用程序)
查看>>
js中的延迟加载
查看>>
在.NET开发中的单元测试工具之(2)——xUnit.Net
查看>>
微软BI 之SSRS 系列 - 使用带参数的 MDX 查询实现一个分组聚合功能的报表
查看>>
Direct基础学习系列3 绘制+实例
查看>>
myeclipse报异常:java.lang.OutOfMemoryError: Java heap space
查看>>
JS图片加载时获取图片宽高信息
查看>>
配置 Sliverlight 跨域访问策略
查看>>