mysql给行按顺序添加行号

该博客介绍了如何在SQL查询中利用用户变量进行行号排序,通过设置初始值并逐行递增,实现了对数据表中的记录进行排名。这种方法在不支持窗口函数的数据库系统中特别有用,例如在对班级分数进行排序的同时获取每个学生的名次。
摘要由CSDN通过智能技术生成

背景说明:比如按班级分数排序后,同时获取名次,排序前是没有名次的

使用用户变量语法,@变量名:如 @name

可以先在用户变量中保存值然后在以后引用它;这样可以将值从一个语句传递到另一个语句。用户变量与连接有关。也就是说,一个客户端定义的变量不能被其它客户端看到或使用。当客户端退出时,该客户端连接的所有变量将自动释放。 

直接sql实例

sql如下,说明: rowid 不是关键字,是一个自定义变量名,from后必须对其别名

SELECT
    @rowid :=@rowid + 1 orderno,
    k.user_id
FROM
    USER k,
    (SELECT(@rowid := 0)) a
ORDER BY
    k.score DESC;

结果:如此便类似下标或者行号的功能了

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值