MySQL Max包含错误的字段

时间:2015-09-07 12:01:58

标签: mysql sql max

执行以下查询时

SELECT `game_turns`.`in_darts`, `game_turns`.`date`, MAX(game_turns.score) AS max_score
FROM `game_turns`
JOIN `games` ON `games`.`id` = `game_turns`.`game_id` AND `games`.`training` = 1
WHERE `game_turns`.`uid` = 2
AND `game_turns`.`out` = 1
AND `game_turns`.`in_darts` = 3
ORDER BY `game_turns`.`score` DESC
LIMIT 1

我获得该用户ID(uid)的最高分数,并且在3次飞镖中获得,但其余的(日期)是错误的。

字段

Score   Uid     GameID      Score    out    in_darts    date
121     2       4           8        1      3           2015-07-21 13:52:12
8465    2       142         100      1      3           2015-09-05 19:46:29

它从行ID 8465返回得分100,但其余部分来自行ID 121

我用google搜索了一些Stackoverflow结果,说我应该使用ORDER BY和LIMIT 1,但看起来它不适合我。

按日期排序也没有做到这一点。

2 个答案:

答案 0 :(得分:1)

一个简单的order bylimit应该做你想做的事情:

SELECT gt.`in_darts`, gt.`date`, gt.score
FROM `game_turns` gt JOIN
     `games` g
     ON g.`id` = gt.`game_id` AND g.`training` = 1
WHERE gt.`uid` = 2 AND gt.`out` = 1 AND gt.`in_darts` = 3
ORDER BY gt.`score` DESC
LIMIT 1;

无需聚合。

答案 1 :(得分:0)

如果寻求适用于多个UID的解决方案,则聚合变得有用 - 通过子查询。

SQL Fiddle

MySQL 5.6架构设置

CREATE TABLE Table1
    (`Score_A` int, `Uid` int, `GameID` int, `Score_B` int, `out` int, `in_darts` int, `date` datetime)
;

INSERT INTO Table1
    (`Score_A`, `Uid`, `GameID`, `Score_B`, `out`, `in_darts`, `date`)
VALUES
    (121, 2, 4, 8, 1, 3, '2015-07-21 13:52:12'),
    (8465, 2, 142, 100, 1, 3, '2015-09-05 19:46:29')
;

查询1

SELECT
      t.*
FROM table1 t
INNER JOIN (
  SELECT Uid, max(Score_B) as Score_B
  FROM table1
  GROUP BY uid
  ) msb ON t.Uid = msb.Uid and t.Score_B = msb.Score_B

<强> Results

| Score_A | Uid | GameID | Score_B | out | in_darts |                        date |
|---------|-----|--------|---------|-----|----------|-----------------------------|
|    8465 |   2 |    142 |     100 |   1 |        3 | September, 05 2015 19:46:29 |