MySQL踩坑记之视图添加行号

MySQL踩坑记之视图添加行号

问题背景

最近有一个需求, 需要给数据库中某系数据添加一个行号, 简单来说, 可以认为是按照某种规则进行排序后, 输出每一行的顺序. 这里本以为会进展的比较顺利(内心其实慌得一匹), 虽然作为一个老的Django用户, 我已经好久没有动过原生的SQL语句了, 努(绞尽)力(脑汁)回忆一把之前学过的数据库知识, 想到了这个应该是可以利用视图来实现的, 心想这里加一个行号不就OK了吗?

image

经过一顿冥(上)思(网)苦(搜)想(索), 发现这个对于Oracle来说, 是有自带的函数的, 可怜我用的MySQL, 又不能直接换成Oracle, 只能自己实现, 哎, 感觉自己头发少了好多, 我太难了, 在这里找解决方案的时候, 我遇到了不少的问题, 下面简单记录一下我解决问题的过程, 后面所有的表我都屏蔽了当时的业务, 按照最简化的原则处理.

初始表结构

在这里, 为了简化, 我们只用两个字段, namescore, 然后我们按照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 := 
  • 24
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 18
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值