首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >根据学生的班级对学生进行排名

根据学生的班级对学生进行排名
EN

Stack Overflow用户
提问于 2016-03-26 03:24:09
回答 1查看 79关注 0票数 2

我正在尝试根据学生的分数对他们的班级(exam_place_id)进行排名。

这是我的数据库

例如,exam_place_id 11中得分最高的学生在exam_place_id 12中的最高分也将被排在1位

总体排名是指他们在总体上的得分

我已经做了总体排名

代码语言:javascript
复制
select er.*,
      (@rank := @rank + 1)       as ranking
from examresults er cross join
     (select @rank := 0, @point := -1) params

order by point desc;

然而,当我尝试

代码语言:javascript
复制
select er.*,
      (@rank := @rank + 1)       as ranking
from examresults er cross join
     (select @rank := 0, @point := -1) params
**group by exam_place_id** 
order by point desc;

它不起作用。

注意:我还想用这些值更新我的class_ranking列,但是我的当前查询确实是select。

EN

回答 1

Stack Overflow用户

发布于 2016-03-26 03:31:07

你需要跟踪考试地点,并将其用于排名:

代码语言:javascript
复制
select er.*,
       (@rank := if(@ep = exam_place_id, @rank + 1,
                    if(@ep := exam_place_id, 1, 1) 
                   )
       ) as ranking
from examresults er cross join
     (select @rank := 0, @ep := -1) params
order by exam_place_id,
         point desc;
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36226569

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档