Heim > Datenbank > MySQL-Tutorial > Wie kann ich den neuesten Eintrag für jede Gruppe in einer Datenbanktabelle effizient abrufen?

Wie kann ich den neuesten Eintrag für jede Gruppe in einer Datenbanktabelle effizient abrufen?

Barbara Streisand
Freigeben: 2025-01-25 19:53:09
Original
786 Leute haben es durchsucht

How can I efficiently retrieve the latest entry for each group in a database table?

Erhalten Sie effizient die neuesten Einträge jeder Gruppe

Das Ziel besteht darin, den neuesten Eintrag für jede eindeutige Gruppe aus einer Datenbanktabelle wie DocumentStatusLogs abzurufen. Diese Tabelle enthält eine Reihe von Dokumentstatusänderungsdatensätzen. Jedes Dokument ist durch DocumentID gekennzeichnet. Die Aufgabe besteht darin, den neuesten Aktualisierungsstatus jedes Dokuments und das zugehörige Datum zu extrahieren.

Überlegungen zur Datenbanknormalisierung

Zunächst müssen wir prüfen, ob das Datenbankdesign ordnungsgemäß normalisiert wurde. Sollen Zustandsinformationen in der übergeordneten oder der untergeordneten Tabelle gespeichert werden? Wenn Sie nur auf den aktuellen Status jedes Dokuments zugreifen müssen, ist es besser, das Statusfeld direkt zur übergeordneten Tabelle hinzuzufügen und die Verwendung einer separaten Tabelle zum Verfolgen von Statusänderungen zu vermeiden. Wenn Sie jedoch einen Verlauf der Statusaktualisierungen führen müssen, bietet die Verwaltung von Statusänderungen in einer separaten Tabelle Vorteile.

Top-Eintrag abrufen

Zurück zur ursprünglichen Frage: Es gibt keine integrierte Aggregatfunktion, die den obersten Eintrag jeder Gruppierung direkt abrufen kann. Daher sind zusätzliche Abfragen oder Unterabfragen erforderlich, um die gewünschten Ergebnisse zu erzielen.

Unterabfrage CTE verwenden

Ein Ansatz besteht darin, einen gemeinsamen Tabellenausdruck (CTE) zu erstellen, um Zwischenergebnisse zu generieren. Ein CTE namens cte erweitert die Originaltabelle, indem es jedem Eintrag eine Zeilennummer hinzufügt. Diese Zeilennummer wird innerhalb jeder DocumentID-Gruppierung generiert und in absteigender Reihenfolge nach DateCreated sortiert.

<code class="language-sql">WITH cte AS
(
   SELECT *,
         ROW_NUMBER() OVER (PARTITION BY DocumentID ORDER BY DateCreated DESC) AS rn
   FROM DocumentStatusLogs
)
SELECT *
FROM cte
WHERE rn = 1</code>
Nach dem Login kopieren

Diese Abfrage wählt die gesamte Zeile aus der cte-Tabelle mit der Zeilennummer (rn) gleich 1 aus und stellt somit effektiv den obersten Eintrag für jede DocumentID-Gruppierung bereit.

Alternative Methoden

Ein anderer Ansatz besteht darin, die Funktion DENSE_RANK anstelle von ROW_NUMBER zu verwenden, insbesondere wenn Sie für jedes DocumentID an einem bestimmten Datum mehrere Einträge erwarten. DENSE_RANK stellt sicher, dass alle Einträge für ein bestimmtes Datum die gleiche Rangfolge erhalten, sodass Sie bei Bedarf zwei Einträge für dieses Datum abrufen können.

Fazit

Durch die Nutzung der oben genannten Technik können Sie den neuesten Eintrag für jede Gruppierung effizient extrahieren, indem Sie entweder einen Unterabfrage-CTE oder die Funktion DENSE_RANK verwenden. Welche Methode Sie wählen, hängt von Ihren Datenanforderungen und Leistungsaspekten ab.

Das obige ist der detaillierte Inhalt vonWie kann ich den neuesten Eintrag für jede Gruppe in einer Datenbanktabelle effizient abrufen?. 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