![]() |
Datenbank: MySQL • Version: 5+ • Zugriff über: Konsole
Select mit Where-Klausel und von dessem Ergebnis alle "Unterdaten" ermitteln
Hallo!
Ich habe mal wieder ein Problem mit einem SQL-Statement. Ich habe zwei Tabellen, eine Kunden-Tabelle und eine kundenbezogene Tabelle, die mehrere Einträge pro Kunde enthalten kann. Ich möchte jetzt eine Abfrage erstellen, dir mir folgendes liefert. Alle Kunden, deren Nachname mit [Buchstabe] beginnt und von jedem einzelnen Kunden alle Einträge aus der kundenspezifischen Tabelle. Dies könnte so aussehen:
Code:
Das Problem ist nicht das mit dem Anfangsbuchstaben. Das Problem ist das auslesen der weiteren Datensätze aus der anderen Tabelle. Einen JOIN oder so bekomme ich nicht hin aber mehrere Abfragen möchte ich auch nicht ausführen (Serverlast).
Suche nach "M"
Müller, Klaus | Tacker | Locher | Heftklammern Meyer, Uli | Blöcke Maier, Frank | Tacker | Blöcke .... ... .... ... ... .. Oder soll ich zwei Abfragen ausführen - eine für die Kunden mit [Buchstabe] und dann eine mit den Kundendaten und diese zwei Ergebnisse durch Sortieralgorithmen zusammenführen? Vielen Dank im Voraus. |
AW: Select mit Where-Klausel und von dessem Ergebnis alle "Unterdaten" ermitteln
Warum keinen JOIN?
Nehmen wir mal an, die Tabellen heissen "kunden" und "kunden_data", du willst alle Felder und der Primary Key aus Kunden heisst ID, in kunden_data der zugehörige Fremdschlüssel kundenID:
Code:
Damit bekommst du für jeden Eintrag der kunden_data Tabelle eine Ergebniszeile, mit dem entsprechenden, übergeordneten Datensatz der kunden-Tabelle zusammengefügt, alphabetisch nach Nachname und Vorname geordnet:
SELECT kunden.*,kunden_data.* FROM kunden INNER JOIN kunden_data ON kunden.ID=kunden_data.KundenID WHERE kunden.nachname LIKE ('M%') ORDER BY kunden.nachname ASC, kunden.vorname ASC, kunden.ID ASC;
kunden.ID kunden.nachname kunden.vorname kunden_data.artikel ----------------------------------------------------------------- 0 Maier Frank Tacker 0 Maier Frank Blöcke 1 Meyer Uli Blöcke 2 Müller Klaus Tacker 2 Müller Klaus Locher 2 Müller Klaus Heftklammern usw.... Das kannst du dann clientseitig auswerten und dementsprechend anzeigen. (z.B. in einer Schleife, solange sich beim Durchgehen der Datensätze die kunden.ID nicht ändert, ist es der gleiche Kunde usw.) P.S: Wenn du ebenso alle Datensätze aus kunden haben willst, die keinen eintrag in kunden_data haben, dann brauchst du einen LEFT JOIN. Optimieren kannst du das natürlich, indem du nicht alles (*) aus beiden Tabellen holst, sondern nur die Felder, die du auch brauchst. Das ganze ging auch noch als zweiter Weg über SubSelects, aber der mySQL-Optimizer mag JOINS lieber als Subselects, auch wenn diese oft sehr praktisch sind. |
AW: Select mit Where-Klausel und von dessem Ergebnis alle "Unterdaten" ermitteln
Hallo,
auf dieser Seite gibt es zu SQL und anderem gute Erklärung. Schönes Nachschlagewerk. ![]() Grüße |
AW: Select mit Where-Klausel und von dessem Ergebnis alle "Unterdaten" ermitteln
Rückfrage, wofür soll das gut sein?
Einzig für die Darstellung? Dann würde ich Dir empfehlen, das über Delphi zu lösen. Wenn es über reines SQL gehen soll, dann nimm soetwas
Code:
wahrscheinlich mußt Du
select Kundenname ,Produktname
from... where ... and produktid=max(produktid) ... union select ' ',produktname from where ... and produktid<>max(produktid) order by kundenid
Code:
durch einen Subselect ersetzen.
max(produktid)
Wichtig ist, daß Du die Datensätze mit ond ohne Namen sauber voneinander trennen kannst. Gruß K-H |
AW: Select mit Where-Klausel und von dessem Ergebnis alle "Unterdaten" ermitteln
Im Prinzip sehe ich das so wie blackfin...
Ich würde das allerdings kürzer und übersichtlicher formatieren (ist nur Geschmacksache):
SQL-Code:
SELECT *
FROM kunden k INNER JOIN kunden_data kd ON k.ID = kd.KundenID WHERE nachname LIKE 'M%' ORDER BY nachname, vorname, k.ID |
AW: Select mit Where-Klausel und von dessem Ergebnis alle "Unterdaten" ermitteln
Danke für die Antworten. Ich habe das Problem erkannt und ihr konntet nicht wissen, was ich möchte - ich konnte es gestern Abend nicht mehr so recht beschreiben.
Also ich möchte - wenn wir bei dem Beispiel hier bleiben - alle Produkte auflisten, die die Kunden gekauft haben und mit [Buchstabe] anfangen (daher LIKE ('T%')). Unter jedem Kundeneintrag steht dann: Der Kunde hat auch noch [....] gekauft. Dort stehen dann Artikel mit anderen Anfangsbuchstaben - und genau hier liegt das Problem. Ich frage ja in der Tabelle explizit nur nach den Buchstaben mit [Buchstabe], will dann aber auch alle anderen anzeigen. Bleibt da jetzt nur ein SubSelect (und wenn ja wie performant ist dieser), oder soll ich mir alle Daten laden, diese dann nach Buchstaben sortieren und den mit [Buchstabe] ganz oben anzeigen? Ich arbeite in PHP. Vielen Dank im Voraus und sry für die schlechte Beschreibung gestern. |
AW: Select mit Where-Klausel und von dessem Ergebnis alle "Unterdaten" ermitteln
Zitat:
Soll jetzt beim Kundennamen oder beim Produktnamen nach dem Anfangsbuchstaben gesucht werden? Am besten du gibst mal ein paar Beispieldaten (vor allem auch solche, die nicht angezeigt werden sollen) und dann das gewünschte Ergebnis. Im Moment ist das noch etwas konfus |
AW: Select mit Where-Klausel und von dessem Ergebnis alle "Unterdaten" ermitteln
Liste der Anhänge anzeigen (Anzahl: 1)
Morgen,
ich sehe gerade, dass mein Beispiel auf dem ersten Post auch recht misslungen ist. Es soll nicht nach Kundenname, sondern nach Produktname sortiert werden. Also ganz konkret: Zeige mir alle Kunden, die Produkte mit [Buchstabe] gekauft haben, und unter jedem Kundeneintrag noch weitere Produkte, die er auch (mal) gekauft hat. Fragt bitte nicht nach dem Sinn und Zweck - ich brauche dieses Ergebnis. Die Frage ist nur, wie ich eine solche Sache performant löse. Einmal Frage ich die Produkttabelle mit Kondition ab, einmal ohne. Soll ich mir nicht einfach einmal alle Daten holen und dann sortieren, oder lieber ein SubSelect etc benutzen? Ich habe nochmal ein Bild angehängt, wie das Ergebnis aussehen könnte. Danke nochmal. |
AW: Select mit Where-Klausel und von dessem Ergebnis alle "Unterdaten" ermitteln
Obwohl ich das Gefühl habe, dass da noch eine Tabelle fehlt (ungetestet):
SQL-Code:
P2.Name könnte man ggf. noch mit GROUP_CONCAT zusammenfassen, um das Ergebnis wie in Deinem Beispiel zu erhalten.
SELECT
K.Name, P2.Name FROM Produkte P JOIN Kunden K ON K.ID = P.Kunden_ID JOIN Produkte P2 ON P2.Kunden_ID = K.ID WHERE P.Name LIKE 'T%' |
AW: Select mit Where-Klausel und von dessem Ergebnis alle "Unterdaten" ermitteln
@DeddyH: Ich kann mich täuschen, aber holt deine Abfrage nicht nur die Datensätze, bei denen der Produktname mit 'T' anfängt? (jedoch nicht die anderen für die Anzeige "Hat auch nocht gekauft: xxx")
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 03:58 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz