AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Ergebnis eines Selects in Spalten eines anderen Selects darstellen
Thema durchsuchen
Ansicht
Themen-Optionen

Ergebnis eines Selects in Spalten eines anderen Selects darstellen

Ein Thema von Hobbycoder · begonnen am 29. Aug 2018 · letzter Beitrag vom 30. Aug 2018
 
Hobbycoder

Registriert seit: 22. Feb 2017
998 Beiträge
 
#1

Ergebnis eines Selects in Spalten eines anderen Selects darstellen

  Alt 29. Aug 2018, 12:54
Datenbank: MySQL • Version: 5.6 • Zugriff über: Zeos
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.
Gruß Hobbycoder
Alle sagten: "Das geht nicht.". Dann kam einer, der wusste das nicht, und hat's einfach gemacht.
  Mit Zitat antworten Zitat
 


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 04:07 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