加入收藏 | 设为首页 | 会员中心 | 我要投稿 武汉站长网 (https://www.027zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

mysql排序输出序号_MySQL的排序并取得对应序号

发布时间:2023-01-31 10:04:07 所属栏目:MySql教程 来源:未知
导读: 现在需要实现这么一个功能:对数据库中的对应年龄的儿童的身高排序,并得到指定ID儿童的身高排名。就是比如要查询ID为9527的这名8岁儿童的身高在所有8岁儿童身高中的排名。数据库学得不深,

现在需要实现这么一个功能:对数据库中的对应年龄的儿童的身高排序,并得到指定ID儿童的身高排名。就是比如要查询ID为9527的这名8岁儿童的身高在所有8岁儿童身高中的排名。数据库学得不深,一般就进行增减改删,所以不知道怎么实现这个功能。

网上查询了一些资料MySQL 排序,就是先进行排序,生成行序号,然后返回对应儿童ID的序号,有个相似语句如下

select id,height,(@rowno:=@rowno+1) as rowno from test,(select (@rowno:=0)) b

order by height desc;

在此基础上再查询位置:

select rowno from (select id,height,(@rowno:=@rowno+1) as rowno from test,

(select (@rowno:=0)) b order by height desc) c where id = 9527;

我的问题是:

1.语句中的(@rowno:=@rowno+1)、(select (@rowno:=0)) 、b、C 是什么意思,查了一下大致知道是自定义命名赋值之类的,但是不清楚准确该怎么理解,还有出现的 b 和 c是什么意思?

2.我要在该语句基础上加一个条件,就是八岁儿童的身高排名,也就是要在第一条排序语句中加入where age equals 8 这句话应该加在哪里? 我试过加在 from test 后面和其他几个地方都报错了,不知道该怎么加。

困扰了一天了,希望数据库的大虾们帮助解答一下这两个问题,万分感谢!!!

(编辑:武汉站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!