Problem:
Eine MySQL-Tabelle speichert die Antworten auf verschiedene RPC Aufrufe mit Feldern für Zeitstempel, Methode, ID und Antwort. Ziel ist es, die aktuellsten Antworten für alle Kombinationen aus Methode und ID abzurufen.
Annahmen:
Lösung:
Die folgende Abfrage kann verwendet werden, um das gewünschte Ergebnis mithilfe von MySQL-Variablen effizient abzurufen um einen JOIN zu vermeiden:
SELECT * FROM ( SELECT *, if(@last_method=method,0,1) as new_method_group, @last_method:=method FROM rpc_responses ORDER BY method, timestamp DESC ) as t1 WHERE new_method_group=1;
Diese Abfrage weist zunächst jeder Zeile einen new_method_group-Wert zu, der den Beginn einer neuen Methode angibt Gruppe. Anschließend werden die Ergebnisse so gefiltert, dass nur Zeilen mit einem new_method_group-Wert von 1 enthalten sind. Dadurch wird sichergestellt, dass nur die aktuellste Zeile für jede Methode im Endergebnis enthalten ist.
Alternative Lösung für PostgreSQL:
PostgreSQL bietet eine integrierte Funktion für diese Aufgabe:
SELECT DISTINCT ON (method) timestamp, method, id, response FROM rpc_responses WHERE 1 # some where clause here ORDER BY method, timestamp DESC
Das obige ist der detaillierte Inhalt vonWie kann ich die neuesten Datensätze für jede Methode und ID in MySQL und PostgreSQL effizient abrufen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!