SELECT * FROM ScoresTable WHERE Score = (SELECT MAX(Score) FROM ScoresTable AS st WHERE st.Date = ScoresTable.Date)
在WHERE子句中有使用SELECT语句描述的名称吗?这是好/不好的做法吗?
这会是更好的选择吗?
SELECT ScoresTable.* FROM ScoresTable INNER JOIN (SELECT Date, MAX(Score) AS MaxScore FROM ScoresTable GROUP BY Date) SubQuery ON ScoresTable.Date = SubQuery.Date AND ScoresTable.Score = SubQuery.MaxScore
它远没有那么优雅,但是运行起来比以前的版本要快。我不喜欢它,因为它在GUI中没有非常清晰地显示(并且SQL初学者需要理解它)。我可以将其分为两个独立的查询,但是随后事情变得混乱了……
注意:我不仅需要日期和分数(例如姓名)
称为相关子查询。它有它的用途。