我正在尝试关注此示例:MySQL - ranking by count() and GROUP BY但我的rank
列保持返回nil。
这是我的疑问:
SELECT
@rownum := @rownum+1 AS rank,
q.id,
q.Name,
q.count
FROM
(SELECT
Accounts.id,
Accounts.Name,
COUNT(Accounts.Name) AS count
FROM
player_to_team_histories
INNER JOIN
team_histories ON team_histories.id = player_to_team_histories.team_history_id
INNER JOIN
teams ON teams.id = team_histories.team_id
INNER JOIN
accounts ON accounts.id = teams.account_id
WHERE
accounts.AccountTypeId = 1 AND player_id IN (SELECT
player_id
FROM
player_to_team_histories
WHERE
player_to_team_histories.not_valid IS NULL AND team_history_id = (SELECT
team_history_id
FROM
player_to_team_histories
INNER JOIN
team_histories ON team_histories.id = player_to_team_histories.team_history_id
WHERE
player_to_team_histories.id = 574651))
GROUP BY Accounts.Name
ORDER BY count DESC)q
除rank
之外的所有列都按预期返回,rank
每行返回null
。
答案 0 :(得分:0)
你必须在开始递增之前将你的rownum初始化为0,或者通过
SET @rownum := 0;
在查询之前,或在您的第一个SELECT
之后单独的FROM
子句:
SELECT ...
FROM
(SELECT @rownum := 0 ) counter,
(SELECT
... )