Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Select mit Where-Klausel und von dessem Ergebnis alle "Unterdaten" ermitteln (https://www.delphipraxis.net/160770-select-mit-where-klausel-und-von-dessem-ergebnis-alle-unterdaten-ermitteln.html)

TheMiller 30. Mai 2011 23:15

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:
Suche nach "M"
Müller, Klaus  | Tacker
                | Locher
                | Heftklammern
Meyer, Uli     | Blöcke
Maier, Frank   | Tacker
                | Blöcke
.... ... .... ... ... ..
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).
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.

blackfin 30. Mai 2011 23:30

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:
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;
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:


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.

simmi 31. Mai 2011 09:36

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.
http://sql.1keydata.com/de/

Grüße

p80286 31. Mai 2011 10:35

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:
select Kundenname ,Produktname
from...
where ...
and produktid=max(produktid)
...
union
select '     ',produktname
from
where ...
and produktid<>max(produktid)
order by kundenid
wahrscheinlich mußt Du
Code:
max(produktid)
durch einen Subselect ersetzen.
Wichtig ist, daß Du die Datensätze mit ond ohne Namen sauber voneinander trennen kannst.

Gruß
K-H

omata 31. Mai 2011 11:11

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

TheMiller 31. Mai 2011 17:49

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.

Sir Rufo 31. Mai 2011 18:32

AW: Select mit Where-Klausel und von dessem Ergebnis alle "Unterdaten" ermitteln
 
Zitat:

Zitat von DJ-SPM (Beitrag 1103974)
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.

:wiejetzt:
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

TheMiller 1. Jun 2011 09:10

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.

DeddyH 1. Jun 2011 09:28

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:
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%'
P2.Name könnte man ggf. noch mit GROUP_CONCAT zusammenfassen, um das Ergebnis wie in Deinem Beispiel zu erhalten.

blackfin 1. Jun 2011 09:45

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 15:44 Uhr.
Seite 1 von 2  1 2      

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz