2010-02-12 12 views
5

Wie gibt es Top-Schlüsselwort in SQL Server 2005, wie oben 1 Zeile in mysql auswählen, wenn ich auf mehrere Tabelle & wollen Extreme jeder ID/Spalte abrufen. Limit beschränkt die Nr. der Reihe kehrt zurück, damit es mein Problem nicht lösen kann.MYSQL top N Zeilen aus mehreren Tabellen Join

+0

Vielleicht ein Beispiel? – hsz

+0

Ja, die Frage ist nicht sehr klar. Ich habe nur getippt –

+0

Die Frage ist nicht sehr klar, aber ich denke, es ist ein weiterer Fall der "größten-n-pro-Gruppe" Problem, das häufig auftritt. –

Antwort

3
SELECT v.* 
FROM document d 
OUTER APPLY 
     (
     SELECT TOP 1 * 
     FROM version v 
     WHERE v.document = d.id 
     ORDER BY 
       v.revision DESC 
     ) v 

oder

SELECT v.* 
FROM document d 
LEFT JOIN 
     (
     SELECT *, ROW_NUMBER() OVER (PARTITION BY v.id ORDER BY revision DESC) 
     FROM version 
     ) v 
ON  v.document = d.id 
     AND v.rn = 1 

Letzteres ist effizienter, wenn Sie Ihre Dokumente in der Regel wenige Revisionen haben, und Sie müssen alle oder fast alle Dokumente auszuwählen; ersteres ist effizienter, wenn die Dokumente viele Revisionen haben oder Sie nur eine kleine Teilmenge von Dokumenten auswählen müssen.

Update:

Sorry, habe die Frage nicht bemerkt, ist etwa MySQL.

In MySQL, tun Sie es so:

SELECT * 
FROM document d 
LEFT JOIN 
     version v 
ON  v.id = 
     (
     SELECT id 
     FROM version vi 
     WHERE vi.document = d.document 
     ORDER BY 
       vi.document DESC, vi.revision DESC, vi.id DESC 
     LIMIT 1 
     ) 

erstellen Composite-Index auf version (document, revision, id) für diese schnell zu arbeiten.

+0

MySQL unterstützt 'APPLY' oder' ROW_NUMBER() '(Fensterfunktionen) nicht. –

+0

@Bill: Richtig, habe nicht bemerkt, dass es um 'MySQL' geht. – Quassnoi

+0

Spätere Antwort funktioniert, aber was ist, wenn für einige Zeilen ich nur einen Datensatz haben ex: Version haben nur einen Datensatz für eine bestimmte docID in diesem Fall Abfrage abrufen keine Zeilen für diese ID. Sorry für späte Antwort/Kommentar –

0

Wenn ich Sie richtig verstehe, löst Top auch Ihr Problem nicht. oben entspricht genau der Grenze. Was Sie suchen, sind Aggregatfunktionen, wie max() oder min(), wenn Sie die Extreme wollen. zum Beispiel:

select link_id, max(column_a), min(column_b) from table_a a, table_b b 
where a.link_id = b.link_id group by link_id