MySQL选择排名

MySQL选择排名,mysql,Mysql,我有一个竞争,销售代表可以进入许多不同的商店,商店根据进入商店的人进行积分 我需要做的是根据分值选择一个门店的排名(其中id=x),如果一个门店平局,那么排名应该是相同的(即两个门店首先合并) 然后,我需要根据代表商店得分的总和来选择代表的排名 商店 id name points rep_id 1 Regents Street 1501 3 2 Oxford Street 1500 2 3 Carnaby Street 1499 3 4 Edw

我有一个竞争,销售代表可以进入许多不同的商店,商店根据进入商店的人进行积分

我需要做的是根据分值选择一个门店的排名(其中id=x),如果一个门店平局,那么排名应该是相同的(即两个门店首先合并)

然后,我需要根据代表商店得分的总和来选择代表的排名

商店

id  name    points  rep_id
1   Regents Street  1501    3
2   Oxford Street   1500    2
3   Carnaby Street  1499    3
4   Edward Street   1499    1
5   Edward Street   1499    4
代表

商店排行榜:

1st - 1, Regents Street
2nd - 2, Oxford Street
3rd - 3,4,5
1st - 3, Joe Smit (3000)
2nd - 2, John Doe (1500)
3rd - 1,4 (1499)
代表排行榜:

1st - 1, Regents Street
2nd - 2, Oxford Street
3rd - 3,4,5
1st - 3, Joe Smit (3000)
2nd - 2, John Doe (1500)
3rd - 1,4 (1499)
我有一个查询来获取商店排名,但它不适用于领带

    SELECT id,
       name,
       points,
       FIND_IN_SET(points,
                     (SELECT GROUP_CONCAT(points
                                          ORDER BY points DESC)
                      FROM stores)) AS rank
FROM stores
WHERE id = 1

谢谢

我通常会使用变量进行此类排名:

select s.*,
       (@rn := if(@p = points, @rn,
                  if(@p := points, @rn + 1, @rn + 1)
                 )
       ) as rank
from stores s cross join
     (select @rn := 0, @p := -1)
order by s.points desc;
另一种方法是相关子查询:

select s.*,
       (select count(distinct s2.points)
        from stores s2
        where s2.points >= s.points
       ) as rank
from store s;
这两个查询实际上都实现了一个
densed\u rank()
,而不是
rank()
。你的问题不清楚你到底想要什么。而且,它们也可以修改为一个等级

编辑:

如果您需要为销售代表而不是商店(这似乎隐藏在问题的开头):

我认为这将在MySQL中起作用:

select s.rep_id,
       (select count(distinct r2.points)
        from (select s.rep_id, sum(s.points) as points
              from stores s
              group by s.rep_id
             ) r2
        where r2.points >= r.points
       ) as rank
from (select s.rep_id, sum(s.points) as points
      from stores s
      group by s.rep_id
     ) r;

请使用示例数据和期望的结果编辑您的问题。我已根据数据添加了期望的排名。第二个查询提供了我需要的结果,然后我如何根据每个reps stores分数的总和获得相同类型的结果?