MySQL踩坑记之视图添加行号
问题背景
最近有一个需求, 需要给数据库中某系数据添加一个行号, 简单来说, 可以认为是按照某种规则进行排序后, 输出每一行的顺序. 这里本以为会进展的比较顺利(内心其实慌得一匹), 虽然作为一个老的Django用户, 我已经好久没有动过原生的SQL语句了, 努(绞尽)力(脑汁)回忆一把之前学过的数据库知识, 想到了这个应该是可以利用视图来实现的, 心想这里加一个行号不就OK了吗?
经过一顿冥(上)思(网)苦(搜)想(索), 发现这个对于Oracle来说, 是有自带的函数的, 可怜我用的MySQL, 又不能直接换成Oracle, 只能自己实现, 哎, 感觉自己头发少了好多, 我太难了, 在这里找解决方案的时候, 我遇到了不少的问题, 下面简单记录一下我解决问题的过程, 后面所有的表我都屏蔽了当时的业务, 按照最简化的原则处理.
初始表结构
在这里, 为了简化, 我们只用两个字段, name
和 score
, 然后我们按照score
的高低, 进行排序, 添加一列rank
字段.
| name | score |
------------------
| Tom | 100 |
| Smith | 80 |
然后我们要创建的视图如下:
| name | score | rank |
--------------------------
| Tom | 100 | 1 |
| Smith | 80 | 2 |
解决历程
方案一: 查询添加中间变量
虽然作为一个很久不用原生SQL的人, 但是我还是依稀的记得上课中所提到的中间变量的方法的, 所以说最先想到的方案自然是添加查询中间变量了.
SELECT
@i := @i + 1 AS rank,
demo.name,
demo.score
FROM
demo,
( SELECT @i :=