


Wie verwende ich PostgreSQL-Fensterfunktionen korrekt mit GROUP BY-Klauseln?
Jan 06, 2025 am 11:33 AMPostgreSQL-Fensterfunktion und Group By-Ausnahme
Wenn Sie versuchen, eine Fensterfunktion in Verbindung mit einer GROUP BY-Klausel in PostgreSQL zu verwenden, ist es wichtig, den Unterschied zwischen zu verstehen zwei. Fensterfunktionen arbeiten auf einer Partition von Tabellendaten und führen Berechnungen zeilenübergreifend durch, wobei alle Zeilen erhalten bleiben, im Gegensatz zu Aggregatfunktionen, die Zeilen zu einem einzigen Wert zusammenfassen. Daher ist es bei der Verwendung von Fensterfunktionen wichtig, die partitionierten Spalten in die GROUP BY-Klausel aufzunehmen.
Problembeschreibung
In der bereitgestellten Abfrage stößt der Benutzer auf einen Fehler, wenn er versucht, Folgendes auszuführen Code:
SELECT p.name, e.date, sum(sp.payout) OVER (ORDER BY e.date) - sum(s.buyin) OVER (ORDER BY e.date) AS "Profit/Loss" FROM result r JOIN game g ON r.game_id = g.game_id JOIN event e ON g.event_id = e.event_id JOIN structure s ON g.structure_id = s.structure_id JOIN structure_payout sp ON g.structure_id = sp.structure_id AND r.position = sp.position JOIN player p ON r.player_id = p.player_id WHERE p.player_id = 17 GROUP BY p.name, e.date, e.event_id, sp.payout, s.buyin ORDER BY p.name, e.date ASC
Der Fehler tritt auf, weil die Fensterfunktionen sum(sp.payout) OVER (ORDER BY e.date) und sum(s.buyin) OVER (ORDER BY e.date) werden nicht von einer Aggregatfunktion begleitet. Daher verlangt PostgreSQL, dass die partitionierten Spalten sp.payout und s.buyin in die GROUP BY-Klausel aufgenommen werden.
Lösung
Um das Problem zu beheben, kann der Benutzer entweder:
- Beziehen Sie sp.payout und s.buyin in die GROUP BY ein Klausel:
GROUP BY p.name, e.date, e.event_id
Dieser Ansatz kann jedoch zu mehreren Zeilen für jeden Spieler und jedes Ereignis führen, wenn es mehrere sp.payout- oder s.buyin-Werte gibt.
- Verwenden Sie die Kombination aus Fensterfunktionen und Aggregat Funktionen:
SELECT p.name , e.event_id , e.date , sum(sum(sp.payout)) OVER w - sum(sum(s.buyin )) OVER w AS "Profit/Loss" FROM player p JOIN result r ON r.player_id = p.player_id JOIN game g ON g.game_id = r.game_id JOIN event e ON e.event_id = g.event_id JOIN structure s ON s.structure_id = g.structure_id JOIN structure_payout sp ON sp.structure_id = g.structure_id AND sp.position = r.position WHERE p.player_id = 17 GROUP BY e.event_id WINDOW w AS (ORDER BY e.date, e.event_id) ORDER BY e.date, e.event_id;
In diesem Beispiel kombinieren die Ausdrücke sum(sum(sp.payout)) OVER w und sum(sum(s.buyin)) OVER w ein äußeres Fenster Funktion mit einer inneren Aggregatfunktion zur Berechnung der Gesamtauszahlungen und Buyins pro Event.
Das obige ist der detaillierte Inhalt vonWie verwende ich PostgreSQL-Fensterfunktionen korrekt mit GROUP BY-Klauseln?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heißer Artikel

Hot-Tools-Tags

Heißer Artikel

Heiße Artikel -Tags

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Reduzieren Sie die Verwendung des MySQL -Speichers im Docker

Wie verändern Sie eine Tabelle in MySQL mit der Änderungstabelleanweisung?

So lösen Sie das Problem der MySQL können die gemeinsame Bibliothek nicht öffnen

Führen Sie MySQL in Linux aus (mit/ohne Podman -Container mit Phpmyadmin)

Ausführen mehrerer MySQL-Versionen auf macOS: Eine Schritt-für-Schritt-Anleitung

Wie sichere ich mich MySQL gegen gemeinsame Schwachstellen (SQL-Injektion, Brute-Force-Angriffe)?

Wie konfiguriere ich die SSL/TLS -Verschlüsselung für MySQL -Verbindungen?
