Mysql排序增加序号列

今天在Mysql数据库查询数据并进行排序时,感觉没有序号查看排序结果不够直观。示例如下:

--查询部分城市2019年GDP排名
select t.city,t.gdp,t.`year` from city_gdp t where t.`year`='2019' group by t.city,t.gdp,t.`year` order by t.gdp desc;

查询结果: 

 如需增加序号一列,可按如下方式改写sql:

--查询部分城市2019年GDP排名
select @rank:=@rank + 1 AS num,a.* from
(select t.city,t.gdp,t.`year` from city_gdp t where t.`year`='2019' group by t.city,t.gdp,t.`year` order by t.gdp desc) a,
(SELECT @rank:= 0) b;

查询结果如下:

 

其中@rank 是 用户自定义的变量,:=是赋值的作用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值