Heim >Datenbank >MySQL-Tutorial >Wie gruppiert und aggregiert man sequentielle numerische Werte in PostgreSQL mithilfe von Unterabfragen?

Wie gruppiert und aggregiert man sequentielle numerische Werte in PostgreSQL mithilfe von Unterabfragen?

Patricia Arquette
Patricia ArquetteOriginal
2025-01-09 13:26:42638Durchsuche

How to Group and Aggregate Sequential Numeric Values in PostgreSQL Using Subqueries?

Gruppieren und Aggregieren kontinuierlicher numerischer Werte mithilfe von Unterabfragen in PostgreSQL

Beim Umgang mit Tabellen mit numerischen Daten ist es oft notwendig, die Werte entsprechend ihrer Reihenfolge zu gruppieren und zu aggregieren. In PostgreSQL 9.0 und höher können Sie dazu eine Kombination von Unterabfragen verwenden.

Identifizieren Sie nicht kontinuierliche Werte

Der erste Schritt besteht darin, nicht aufeinanderfolgende Werte im numerischen Zielfeld zu identifizieren. Dies kann mit einer Unterabfrage erfolgen, die jeder Zeile eine Gruppenanzahl zuweist und den Zähler zurücksetzt, wenn nicht aufeinanderfolgende Werte auftreten.

<code class="language-sql">SELECT company, profession, year,
       CASE
           WHEN row_number() OVER (PARTITION BY company, profession ORDER BY year) = 1
               OR year - lag(year, 1, year) OVER (PARTITION BY company, profession ORDER BY year) > 1
           THEN 1
           ELSE 0
       END AS group_cnt
FROM qualification;</code>

Gruppen-ID definieren

Als nächstes erstellen wir Gruppen-IDs für jede aufeinanderfolgende Wertefolge. Dabei handelt es sich um eine weitere Unterabfrage, die die Gruppenanzahl aus der vorherigen Unterabfrage summiert.

<code class="language-sql">SELECT company, profession, year,
       SUM(group_cnt) OVER (ORDER BY company, profession, year) AS group_nr
FROM (
    SELECT company, profession, year,
           CASE
               WHEN row_number() OVER (PARTITION BY company, profession ORDER BY year) = 1
                   OR year - lag(year, 1, year) OVER (PARTITION BY company, profession ORDER BY year) > 1
               THEN 1
               ELSE 0
           END AS group_cnt
    FROM qualification
) t1;</code>

Endgültige Aggregation

Abschließend aggregieren wir die Werte für jede Gruppe anhand der Gruppen-ID.

<code class="language-sql">SELECT company, profession, array_agg(year) AS years
FROM (
    SELECT company, profession, year,
           SUM(group_cnt) OVER (ORDER BY company, profession, year) AS group_nr
    FROM (
        SELECT company, profession, year,
               CASE
                   WHEN row_number() OVER (PARTITION BY company, profession ORDER BY year) = 1
                       OR year - lag(year, 1, year) OVER (PARTITION BY company, profession ORDER BY year) > 1
                   THEN 1
                   ELSE 0
               END AS group_cnt
        FROM qualification
    ) t1
) t2
GROUP BY company, profession, group_nr
ORDER BY company, profession, group_nr;</code>

Diese Abfrage gibt eine Tabelle mit eindeutigen Unternehmens- und Berufskombinationen zurück, wobei die Jahreswerte basierend auf ihrer numerischen Reihenfolge in Arrays gruppiert sind. Diese Methode gruppiert effektiv kontinuierliche numerische Folgen, um die anschließende Analyse und Verarbeitung zu erleichtern.

Das obige ist der detaillierte Inhalt vonWie gruppiert und aggregiert man sequentielle numerische Werte in PostgreSQL mithilfe von Unterabfragen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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