Heim > Datenbank > MySQL-Tutorial > Wie kann ich das Aggregieren von Spalten mit unterschiedlichen Filtern in PostgreSQL vereinfachen?

Wie kann ich das Aggregieren von Spalten mit unterschiedlichen Filtern in PostgreSQL vereinfachen?

Linda Hamilton
Freigeben: 2025-01-22 17:26:10
Original
884 Leute haben es durchsucht

How Can I Simplify Aggregating Columns with Distinct Filters in PostgreSQL?

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>
Nach dem Login kopieren

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>
Nach dem Login kopieren

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!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage