Heim >Datenbank >MySQL-Tutorial >Wie rufe ich die letzte Zeile für jede eindeutige ID in PostgreSQL ab?

Wie rufe ich die letzte Zeile für jede eindeutige ID in PostgreSQL ab?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2025-01-01 09:06:11199Durchsuche

How to Retrieve the Last Row for Each Unique ID in PostgreSQL?

Letzte Zeile für jede ID in PostgreSQL abrufen

Bei der Arbeit mit Daten ist es oft notwendig, bestimmte Informationen aus verschiedenen Datensätzen zu extrahieren. Im Fall von PostgreSQL können Benutzer auf Szenarien stoßen, in denen sie den neuesten Datensatz für jede eindeutige ID abrufen müssen.

Szenario

Beachten Sie die folgende Tabelle:

id date another_info
1 2014-02-01 kjkj
1 2014-03-11 ajskj
1 2014-05-13 kgfd
2 2014-02-01 SADA
3 2014-02-01 sfdg
3 2014-06-12 fdsA

Ziel

Das Ziel besteht darin, die letzte Datenzeile für jede eindeutige ID in einer neuen zu extrahieren Tabelle:

id date another_info
1 2014-05-13 kgfd
2 2014-02-01 SADA
3 2014-06-12 fdsA

Lösung 1: Verwendung des DISTINCT ON-Operators von Postgres

Der DISTINCT ON-Operator von Postgres bewältigt dieses Szenario effizient:

select distinct on (id) id, date, another_info
from the_table
order by id, date desc;

Lösung 2: Verwendung von a Fensterfunktion

Aus Gründen der datenbankübergreifenden Kompatibilität können Fensterfunktionen wie row_number() verwendet werden verwendet:

select id, date, another_info
from (
  select id, date, another_info, 
         row_number() over (partition by id order by date desc) as rn
  from the_table
) t
where rn = 1
order by id;

Benchmarks zeigen typischerweise an, dass der Fensterfunktionsansatz schneller ist als Unterabfragen.

Das obige ist der detaillierte Inhalt vonWie rufe ich die letzte Zeile für jede eindeutige ID in PostgreSQL ab?. 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