0

我有一个问答游戏,我想奖励用户进行 2 项活动:
1)正确回答
2)向问题池发送问题

我想查询特定玩家的得分和排名,我使用这个查询:

SELECT (correct*10+sent*30) AS score, @rank:=@rank+1 AS rank 
FROM   (  trivia_players 
          JOIN (  SELECT COUNT(*) AS sent, senderid 
                  FROM trivia_questions 
                  WHERE senderid='$userid'
               ) a 
          ON trivia_players.userid=a.senderid
       )  
       ORDER BY score DESC

如果玩家在两个表中,即正确回答并发送了一个问题,它就会起作用。但如果玩家没有发送问题,它就不起作用

知道如何解决此查询吗?($userid 是给定的参数)

谢谢!

谢谢汤姆!唯一的问题是排名不正确:
userid score rank
58217 380 1
12354 80 3
32324 0 2

4

2 回答 2

1

我可能会这样做:

SELECT
    user_id,
    score,
    rank
FROM
(
    SELECT
        TP.user_id,
        (TP.correct * 10) + (COUNT(TQ.sender_id) * 30) AS score,
        @rank:=@rank + 1 AS rank
    FROM
        Trivia_Players TP
    LEFT OUTER JOIN Trivia_Questions TQ ON
        TQ.sender_id = TP.user_id
    GROUP BY
        TP.user_id,
        TP.correct
    ORDER BY
        score DESC
) AS SQ
WHERE
    SQ.user_id = $user_id

我不怎么用 MySQL,所以语法可能不完美。我认为您可以在 MySQL 中使用这样的子查询。假设 MySQL 通过仅​​计算具有非空值的行来处理 COUNT() ,这应该可以工作。

关键是您对 Trivia Questions 中的非空列进行 COUNT 计算,以便用户对其进行计数,并且您需要使用子查询,以便在限制到特定用户 ID 之前获得每个人的排名。

于 2010-09-07T16:43:37.690 回答
0

您是否尝试过使用RIGHT JOINLEFT JOIN?就在我头顶!

于 2010-09-07T16:35:28.897 回答