SQL - GROUP BY和ORDER BY MIN

问题描述 投票:0回答:2

我有桌面球员的结果:

id | id_user | timems | status | cancel

玩家在开始游戏时选择两种状态:1或2。我列出最佳时间排名:

SELECT *, MIN(timems) AS besttime 
FROM `wyniki` 
WHERE NOT cancel=1 
GROUP BY id_user 
ORDER BY MIN(timems) ASC

这是有效的,但我不知道'状态'的最佳时间是什么。

sql group-by sql-order-by
2个回答
1
投票

此查询容易出错

你可以这样做

SQL查询:

SELECT id_user, status , MIN(timems) AS besttime FROM `wyniki` 
WHERE NOT cancel=1 GROUP BY id_user, status ORDER BY MIN(timems) ASC

0
投票
SELECT id_user, 
       MIN(case when status = 1 then timems else null end) AS best_time_1,
       MIN(case when status = 2 then timems else null end) AS best_time_2
FROM wyniki 
WHERE cancel <> 1 
GROUP BY id_user 
ORDER BY MIN(timems) ASC
© www.soinside.com 2019 - 2024. All rights reserved.