Aiun Geschrieben 4. Februar 2008 Geschrieben 4. Februar 2008 hu, möglich das ich unter Gedächnisschwund leide ^^, habe hier ein SQL-Statement das ich nicht ganz nachvollziehen kann. tabelle2 enthält geloggte Statusmeldungen über Datensätze in Tabelle 1 Tabelle1: - news newsid (Primary Key) Titel Text Tabelle 2: - logs logid (Primary Key) newsid (foreign key) Status (active, old, important) Userid (wer etwas geändert hat) timestamp (wann geändert wurde) nun das Statement: select news.newsid, news.titel, news.text, logs.status, logs.userid, logs.timestamp from news left join logs on logs.newsid = news.newsid group by newsid order by newsid im prinzip ginge es auch ohne left join, kommt etwa aufs gleiche hinaus. Bei dem Statement hätte ich einen Fehler erwartet, da es pro News-Element mehrere Logeinträge mit verschiedenen Stati gibt, aber nur die ID gegroupt wird. Oder wie wird nun bestimmt welcher Datensatz für das Feld logs.Status benutzt wird, wenn am Ende je News nur 1 Ergebnis-Datensatz herauskommt ? (Beispielsituation, hängt mich nicht an der logik der daten auf ^^) danke
Aiun Geschrieben 4. Februar 2008 Autor Geschrieben 4. Februar 2008 ich habe MySQL AB :: MySQL 5.1 Referenzhandbuch :: 12.11.3 GROUP BY mit versteckten Feldern gefunden worin steht: Verwenden Sie diese Funktion nicht, wenn die Spalten, die Sie im GROUP BY-Anteil weglassen, in der Gruppe nicht eindeutig sind! Sie erhalten ansonsten nicht vorhersehbare Ergebnisse. soweit ist doch logs.status nicht eindeutig, oder ?
Empfohlene Beiträge
Erstelle ein Benutzerkonto oder melde Dich an, um zu kommentieren
Du musst ein Benutzerkonto haben, um einen Kommentar verfassen zu können
Benutzerkonto erstellen
Neues Benutzerkonto für unsere Community erstellen. Es ist einfach!
Neues Benutzerkonto erstellenAnmelden
Du hast bereits ein Benutzerkonto? Melde Dich hier an.
Jetzt anmelden