MySQL选择排名
我有一个竞争,销售代表可以进入许多不同的商店,商店根据进入商店的人进行积分 我需要做的是根据分值选择一个门店的排名(其中id=x),如果一个门店平局,那么排名应该是相同的(即两个门店首先合并) 然后,我需要根据代表商店得分的总和来选择代表的排名 商店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 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分数的总和获得相同类型的结果?