Optimierung der Spaltenaggregation mit eindeutigen Filtern in PostgreSQL
Der folgende Code aggregiert Daten aus mehreren Tabellen und wendet unterschiedliche Filter an, um gespielte, gewonnene und verlorene Spiele zu kategorisieren. Obwohl es funktional ist, rechtfertigen seine Komplexität und Länge einen effizienteren Ansatz. In diesem Artikel werden einfachere Methoden untersucht.
Nutzung der FILTER
-Klausel (PostgreSQL 9.4 und höher)
PostgreSQL 9.4 und nachfolgende Versionen bieten die Standard-SQL-FILTER
-Klausel, die eine dynamische Filterung innerhalb von Aggregationen ermöglicht. Dies vereinfacht die Abfrage deutlich:
<code class="language-sql">SELECT u.name, COUNT(*) FILTER (WHERE g.winner_id > 0) AS played, COUNT(*) FILTER (WHERE g.winner_id = u.id) AS won, COUNT(*) FILTER (WHERE g.winner_id <> u.id) AS lost FROM games g JOIN users u ON u.id IN (g.player_1_id, g.player_2_id) GROUP BY u.name;</code>
Alternative für ältere PostgreSQL-Versionen
Für Versionen vor PostgreSQL 9.4 ist eine Problemumgehung mit booleschen Ausdrücken innerhalb der Aggregatfunktion verfügbar:
<code class="language-sql">SELECT u.name, COUNT(g.winner_id > 0 OR NULL) AS played, COUNT(g.winner_id = u.id OR NULL) AS won, COUNT(g.winner_id <> u.id OR NULL) AS lost FROM games g JOIN users u ON u.id IN (g.player_1_id, g.player_2_id) GROUP BY u.name;</code>
Diese Methode ist zwar weniger effizient als die FILTER
-Klausel, bietet aber eine praktische Lösung für ältere PostgreSQL-Installationen.
Zusammenfassung
Die Verwendung der FILTER
-Klausel (PostgreSQL 9.4) oder der booleschen Problemumgehung bietet eine präzisere und in den meisten Fällen leistungsfähigere Lösung. Die FILTER
-Klausel ist aufgrund ihrer verbesserten Lesbarkeit und Effizienz der bevorzugte Ansatz für neuere Versionen. Für ältere Versionen bleibt der boolesche Workaround eine praktikable Alternative.
Das obige ist der detaillierte Inhalt vonWie kann ich das Aggregieren von Spalten mit unterschiedlichen Filtern in PostgreSQL vereinfachen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!