Ich habe einige Tische, an denen die Zeit der Athleten auf einer Strecke aufgezeichnet wird:
Wettbewerbe, Wettbewerbsbenutzer und Wettbewerbsbenutzersitzungen
Ich erstelle eine Abfrage, die den aktuellen Rang und die Gesamtzahl der Konkurrenten für jeden bereitgestellten "Competition_user" extrahiert. Ich kann den Rang in Ordnung bringen, aber meine Anzahl (totalUsers) zählt nicht alle Konkurrenten im Wettbewerb, sondern scheint nur zu zählen an den angegebenen Benutzer (zB gibt das gleiche wie der Rang)
SELECT compUserId, rank, totalUsers
FROM (
SELECT cu.competition_user_id as compUserId, cu.user_id as userId,
count(*) OVER w as totalUsers, rank() OVER w as rank
FROM competition_users cu
LEFT JOIN current_competition_sessions ccs ON cu.competition_user_id = ccs.competition_user_id
LEFT JOIN competition_user_sessions cus ON cus.competition_user_session_id = ccs.competition_user_session_id
WHERE cu.left_competition = false
AND cu.competition_id in (:compIds)
WINDOW w AS (PARTITION BY cu.competition_id ORDER BY cus.time_in_seconds ASC)
) as sub
WHERE compUserId in (:compUserIds)
Mein Verständnis war, dass der Standardrahmen für das gesamte Fenster war, während dies vom Rahmenstart bis zur aktuellen Zeile zu zählen scheint.