我有這種棘手的情況與多個JOINS,我有點卡住了。讓我詳細說明。使用雙GROUP BY時獲得MIN()GROUP BY
我有這些表:
種族
id | system_id | track | race_name | race_date
----------------------------------------------
1 | 3 | Track1| Name | 2016-10-07
2 | 5 | Track1| Name | 2016-10-08
3 | 6 | Track1| Name | 2016-10-09
RACERS
id | system_id | racer_name | gender | bday | from | laps_completed
------------------------------------------------------------------------
1 | 10002 | Name1 | 1 | 1996-10-07|Place | 14
2 | 10003 | Name2 | 0 | 1996-10-08|Place2| 33
3 | 10004 | Name3 | 1 | 1996-10-09|Place3| 44
RACERS_RACES
id | race_id | racer_id
-----------------------
1 | 3 | 10002
2 | 5 | 10004
3 | 6 | 10003
LAPS
id | lap_time | system_id | racer_id
------------------------------------
1 | 25.33 | 1 | 10002
2 | 23.11 | 3 | 10003
3 | 28.55 | 7 | 10004
我試圖這樣做查詢:
SELECT r.system_id,MIN(l.lap_time) as fastest_lap,ra.racer_name,ra.racer_from,r.race_name,ra.laps_completed,r.race_date
FROM races r
LEFT JOIN racers_races rr ON r.system_id=rr.race_id
LEFT JOIN racers ra ON rr.racer_id=ra.system_id
LEFT JOIN laps l ON ra.system_id=l.racer_id
WHERE l.lap_time!=0
GROUP BY r.system_id,l.racer_id
ORDER BY l.lap_time ASCenter code here
我的問題是,當我有多個車手,我有不同種族相同的最快圈速,它不應該是way.It應該返回我最快某賽車手的一圈。
這是一個sqlfiddle鏈接。
見http://meta.stackoverflow.com/questions/333952/why-should-i-provide-我試過你的建議,但它does not工作。也許你有困惑與system_id列。它是分開的對於什麼似乎對我來說是一個非常簡單的SQL查詢 – Strawberry