PostgreSQL-Bedingungszählung: Optimierungsmethode
Beim Zählen der Vorkommen von Daten in einer Datenbanktabelle können bedingte Anweisungen langwierig erscheinen. Glücklicherweise bietet PostgreSQL eine praktische und effiziente Lösung.
FILTER-Aggregationsoptionen
Für PostgreSQL 9.4 und höher nutzen Sie die FILTER-Aggregationsoption für beste Effizienz:
<code class="language-sql">SELECT category , count(*) FILTER (WHERE question1 = 0) AS zero , count(*) FILTER (WHERE question1 = 1) AS one , count(*) FILTER (WHERE question1 = 2) AS two FROM reviews GROUP BY 1;</code>
Präzise Syntax
Wenn Einfachheit für Sie Priorität hat:
<code class="language-sql">SELECT category , count(question1 = 0 OR NULL) AS zero , count(question1 = 1 OR NULL) AS one , count(question1 = 2 OR NULL) AS two FROM reviews GROUP BY 1;</code>
Kreuztabellenabfrage
Um große Optionslisten zu verarbeiten und eine höhere Leistung zu erzielen, sollten Sie die Verwendung der Funktion crosstab() in Betracht ziehen:
<code class="language-sql">SELECT * FROM crosstab( 'SELECT category, question1, count(*) AS ct FROM reviews GROUP BY 1, 2 ORDER BY 1, 2' , 'VALUES (0), (1), (2)' ) AS ct (category text, zero int, one int, two int);</code>
Das obige ist der detaillierte Inhalt vonWie kann ich bedingte Vorkommen in PostgreSQL effizient zählen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!