搜索

首页  >  问答  >  正文

php - MySQL的排序并取得对应序号

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

网上查询了一些资料,就是先进行排序,生成行序号,然后返回对应儿童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 是什么意思,查了一下大致知道是自定义命名赋值之类的,但是不清楚准确该怎么理解,还有出现的 bc是什么意思?

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

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

过去多啦不再A梦过去多啦不再A梦2759 天前668

全部回复(3)我来回复

  • 巴扎黑

    巴扎黑2017-05-16 13:13:51

    1,得到9527的身高为 h
    2,select count(0) from tb where age = 8 and height > h;
    3,那么9527的身高排名就是并列 count + 1,

    回复
    0
  • phpcn_u1582

    phpcn_u15822017-05-16 13:13:51

    不用那么复杂,身高排名,如果从高到低排名,这么计算:
    a=身高字段
    select count(*) from children where
    age=8 and
    a>=(select a from children where id=9527);
    count(*)就是排名

    回复
    0
  • 伊谢尔伦

    伊谢尔伦2017-05-16 13:13:51

    mysql不支持rank方面的函数...在oracle, postgres等等比较强大的数据库里面可以很方便用row_number()实现
    假如数据库的column是id, age, height
    select id, age, height,
    row_number() over (partition by age order by height desc) as rn
    from tb

    回复
    0
  • 取消回复