Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Ergebnis eines Selects in Spalten eines anderen Selects darstellen (https://www.delphipraxis.net/197708-ergebnis-eines-selects-spalten-eines-anderen-selects-darstellen.html)

Hobbycoder 29. Aug 2018 11:54

Datenbank: MySQL • Version: 5.6 • Zugriff über: Zeos

Ergebnis eines Selects in Spalten eines anderen Selects darstellen
 
Hi,

ich habe zwei Tabellen. In der einen stehen die Mitarbeiter (ID, Name, ...) und in einer anderen Tabelle sind Leerlaufzeiten hinterlegt (ID, MitarbeiterID, Leerlaufgrund(als String), Minuten(als Integer), ...).
Wenn der Mitarbeiter nun einen Leerlauf in der Anwendung markiert, wird in der Leerlauftabelle eine Datensatz angelegt, mit seiner MitarbeiterID, einem Leerlaufgrund und Minutenzahl 0. Wird die Leerlaufmarkierung in der Anwendung aufgehoben, so wird die Minutenzahl aktualisiert (passiert noch ein wenig mehr, aber darauf kommt's im Grund an).

Nun möchte ich aus der Tabelle Mintarbeiter alle Zeilen lesen
Code:
select * from Mitarbeiter
, aber diese Tabelle soll um zwei Felder ergänzt werden: Leerlaufgrund(string) und Aktiv(Boolean).
Wenn als ein Datensatz dieses Mitarbeiters mit einer Minutenzahl=0 vorhanden ist, soll als der Leerlaufgrund aus der Leerlaufzeiten und Aktiv=True ausgegeben werden, und wenn eben kein Datensatz auf diese Kriterien zutrifft, dann als Leerlaufgrund einen Leerstring, NULL oder ähnlich und Aktive soll auf False gesetzt werden.

Ungefär so:
Code:
Select m.ID, m.Name, (select a.Leerlaufgrund, a.Minuten from Leerlaufzeiten a where a.MitarbeiterID=??? and a.Minuten=0) from Mitarbeiter m
So geht's aber nicht, weil ich ja an a.MitarbeiterID m.ID übergeben muss. Nur weiß ich nicht wie das in SQL geht, bzw. ob das überhaupt geht.

Das Ergebnis müsste so aussehen:
Code:
ID | Name  | Leerlaufgrund | Aktiv
---+-------+---------------+------
1  | Peter | Aufräumen     | True
2  | Klaus |               | False
Ich brauch mal einen Ansatz wie man das über eine SQL-Abfrage erreichen kann. Hoffentlich habe ich mich verständlich ausgedrückt.

mkinzler 29. Aug 2018 12:03

AW: Ergebnis eines Selects in Spalten eines anderen Selects darstellen
 
Per Join

SQL-Code:
Select
  m.ID, m.Name,
   a.Leerlaufgrund, a.Minuten
from
  Mitarbeiter m
  join Leerlaufzeiten a on a.MitarbeiterID = m.ID
where
  a.Minuten=0;

Hobbycoder 29. Aug 2018 12:21

AW: Ergebnis eines Selects in Spalten eines anderen Selects darstellen
 
Im Prinzip habe ich das auch so machen wollen. Allerding sobald ich a.Minuten=0 hinzufüge bekomme ich nur noch die Mitarbiter, wo eben Minuten=0 als Zeile existiert.
Letztlich möchte alle Mitarbeiter (und auch jeden nur einmal) und dahinter soll, wenn es einen Datensatz in Leerlaufzeiten existiert wo Minuten=0 ist, der Leerlaufgrund und Aktiv=True oder wenn es eben einen solchen Datensatz nicht gibt, dann soll dahinter ein Leerstring und Aktiv=False.

Uwe Raabe 29. Aug 2018 12:30

AW: Ergebnis eines Selects in Spalten eines anderen Selects darstellen
 
Ungetestet, weil ich gerade kein MySQL mit der passenden Database zur Hand habe:
SQL-Code:
Select
  m.ID, m.Name,
  a.Leerlaufgrund,
  (a.Leerlaufgrund IS NOT NULL) AS Active
from
  Mitarbeiter m
  left join Leerlaufzeiten a on (a.MitarbeiterID = m.ID) and (a.Minuten = 0)

p80286 29. Aug 2018 19:53

AW: Ergebnis eines Selects in Spalten eines anderen Selects darstellen
 
Ein
Code:
Select distinct.....
würde Doppeleinträge unterdrücken.

Gruß
K-H

TigerLilly 30. Aug 2018 07:37

AW: Ergebnis eines Selects in Spalten eines anderen Selects darstellen
 
Wenn ich das richtig verstehe:
- es gibt je MitarbeiterIn entweder genau einen Satz mit Minuten=0 ODER einen oder keinen oder mehrere Sätze mit Minuten <>0
- Du möchtest je Mitarbeiter die Info, ob es seinen Satz mit Minuten =0 gibt und wenn ja was der Grund ist

Dann ist dein Ansatz schon gut, aber es geht ein bissl anders:

Code:
Select m.ID, m.Name,
  (select ifnull(a.Leerlaufgrund,'n/a') from Leerlaufzeiten a
    where a.MitarbeiterID=m.ID and a.Minuten=0) as Grund,
  (select case
      when a.minuten is null then 'False'
      when a.minuten =0 then 'True'
      else 'False'
      end
    from Leerlaufzeiten a
    where a.MitarbeiterID=m.ID and a.Minuten=0) as Active,
from Mitarbeiter m
Ist aber ungetestet.

jobo 30. Aug 2018 08:03

AW: Ergebnis eines Selects in Spalten eines anderen Selects darstellen
 
Den Ansatz von Uwe halte ich für den besten und/weil sehr wahrscheinlich auch effizientesten!
Über Mehrfachnennungen wurde vom TE nicht gesagt, wie das ins Ergebnis einfließen soll. Also erstmal alles was da ist, sprich u.U. mehrere Zeilen je Mitarbeiter.


Alle Zeitangaben in WEZ +1. Es ist jetzt 14:36 Uhr.

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