AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Max(Datum) Min(Datum)
Thema durchsuchen
Ansicht
Themen-Optionen

Max(Datum) Min(Datum)

Ein Thema von Metallicwar · begonnen am 18. Apr 2013 · letzter Beitrag vom 15. Mai 2013
Antwort Antwort
Metallicwar

Registriert seit: 5. Feb 2010
Ort: Bad Kissingen
293 Beiträge
 
Delphi XE Architect
 
#1

AW: Max(Datum) Min(Datum)

  Alt 14. Mai 2013, 14:14
Zitat:
1. Anstatt das where anzupassen, das ganze in den join packen (... on ... and buchungsart='P')
Code:
SELECT ma_s.ID, ma_s.Personalnummer as Personalnr, ma_s.Nachname as Name,
       ma_s.Vorname, bd.Datum, bd.Kuerzel, bd.Feiertag, a.Bezeichnung,
       IIF(be.Pause = 0, null, ZMIF.MinToHour(be.Pause)) AS PauseH,
       ZMIF.MinToIHour(be.Pause) as PauseIH,
       IIF(be.Tagesbrutto = 0, null, ZMIF.MinToHour(be.Tagesbrutto)) AS TagesbruttoH,
       ZMIF.MinToIHour(be.Tagesbrutto) as TagesbruttoIH,
       IIF(be.Mehrarbeit = 0, null, ZMIF.MinToHour(be.Mehrarbeit)) AS MehrarbeitH,
       ZMIF.MinToIHour(be.Mehrarbeit) as MehrarbeitIH, b.BuchungsArt,
       min(b.Me1) as Me1,
      max(b.Me2) as Me2, b.Flag
  FROM MA_Stammdaten ma_s
  LEFT OUTER JOIN Abteilungen a
    ON ma_s.ID_Abteilungen = a.ID
  LEFT OUTER JOIN Buchungsdatei bd
    ON ma_s.ID = bd.ID_MA_Stammdaten
  LEFT OUTER JOIN Buchungen b
    ON bd.ID_MA_Stammdaten = b.ID_MA_Stammdaten
   AND bd.Datum = b.Datum and b.BuchungsArt = 'A'
  LEFT OUTER JOIN FEHLTAGEDEFINITION ftd
    ON bd.Fehltag = ftd.Kuerzel
  LEFT OUTER JOIN B_Ergebnisse be
    ON bd.ID = be.ID_Buchungsdatei
 WHERE ma_s.ID IN (3)
   and Month(bd.Datum) = 2
   and Year(bd.Datum) = 2013 
 GROUP BY 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 18
UNION ALL
SELECT ma_s.ID, ma_s.Personalnummer as Personalnr, ma_s.Nachname as Name,
       ma_s.Vorname, bd.Datum, bd.Kuerzel, bd.Feiertag, a.Bezeichnung,
       IIF(be.Pause = 0, null, ZMIF.MinToHour(be.Pause)) AS PauseH,
       ZMIF.MinToIHour(be.Pause) as PauseIH,
       IIF(be.Tagesbrutto = 0, null, ZMIF.MinToHour(be.Tagesbrutto)) AS TagesbruttoH,
       ZMIF.MinToIHour(be.Tagesbrutto) as TagesbruttoIH,
       IIF(be.Mehrarbeit = 0, null, ZMIF.MinToHour(be.Mehrarbeit)) AS MehrarbeitH,
       ZMIF.MinToIHour(be.Mehrarbeit) as MehrarbeitIH, b.BuchungsArt,
      b.Me1, b.Me2, b.Flag         
  FROM MA_Stammdaten ma_s
  LEFT OUTER JOIN Abteilungen a
    ON ma_s.ID_Abteilungen = a.ID
  LEFT OUTER JOIN Buchungsdatei bd
    ON ma_s.ID = bd.ID_MA_Stammdaten
  LEFT OUTER JOIN Buchungen b
    ON bd.ID_MA_Stammdaten = b.ID_MA_Stammdaten
   AND bd.Datum = b.Datum and b.BuchungsArt = 'P'
  LEFT OUTER JOIN FEHLTAGEDEFINITION ftd
    ON bd.Fehltag = ftd.Kuerzel
  LEFT OUTER JOIN B_Ergebnisse be
    ON bd.ID = be.ID_Buchungsdatei
 WHERE ma_s.ID IN (3)
   and Month(bd.Datum) = 2
   and Year(bd.Datum) = 2013
 ORDER By ma_s.ID
Hab die Bedingung für die BuchungsArt nun in den Join gepackt (oben "and b.BuchungsArt = 'A' und unten "and b.BuchungsArt = 'P' wobei ich immmernoch der Meinung bin, dass ich hier "and b.BuchungsArt <> 'A' schreiben muss.
==> In meinem Ergebnis werden jetzt aber wieder nur die Buchungen mit Buchungsart "A" angezeigt

Zitat:
2. Bei der "Berechnung Min/Max" ein IIF einbauen:
min(iif(buchungsart, 'P', b.Me1, null)) as Me1
Code:
SELECT ma_s.ID, ma_s.Personalnummer as Personalnr, ma_s.Nachname as Name,
       ma_s.Vorname, bd.Datum, bd.Kuerzel, bd.Feiertag, a.Bezeichnung,
       IIF(be.Pause = 0, null, ZMIF.MinToHour(be.Pause)) AS PauseH,
       ZMIF.MinToIHour(be.Pause) as PauseIH,
       IIF(be.Tagesbrutto = 0, null, ZMIF.MinToHour(be.Tagesbrutto)) AS TagesbruttoH,
       ZMIF.MinToIHour(be.Tagesbrutto) as TagesbruttoIH,
       IIF(be.Mehrarbeit = 0, null, ZMIF.MinToHour(be.Mehrarbeit)) AS MehrarbeitH,
       ZMIF.MinToIHour(be.Mehrarbeit) as MehrarbeitIH, b.BuchungsArt,
       min(IIF(b.BuchungsArt = 'P', b.Me1, null)) as Me1,
       max(IIF(b.BuchungsArt = 'P', b.Me2, null)) as Me2, b.Flag
Macht meiner Meinung nach keinen Sinn, im max/min Select zu prüfen ob die BuchungsArt 'P' ist, dann werden die 'A' Buchungen genullt und immer noch max/min von 'P' Buchungen angezeigt.

Ich verzweifel langsam an diesem SQL ...
Kollege hat mir vorgeschlagen, mit einem CASE zu arbeiten ?!?
  Mit Zitat antworten Zitat
Benutzerbild von baumina
baumina

Registriert seit: 5. Mai 2008
Ort: Oberschwaben
1.275 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: Max(Datum) Min(Datum)

  Alt 14. Mai 2013, 14:45
Ohne mich jetzt bis ins letzte Detail mit dem select befasst zu haben, hast du mal versucht das "and b.BuchungsArt = xxx" nicht innerhalb des joins sondern erst beim where abzufragen, denn das kann oft ein komplett anderes Ergebnis erzielen?
  Mit Zitat antworten Zitat
Metallicwar

Registriert seit: 5. Feb 2010
Ort: Bad Kissingen
293 Beiträge
 
Delphi XE Architect
 
#3

AW: Max(Datum) Min(Datum)

  Alt 14. Mai 2013, 14:48
Hi,
ja das hab ich auch schon probiert. (wurde in einem vorherigen Post auch schon vorgeschlagen)
Liefert mir aber auch nicht das was ich brauch.
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#4

AW: Max(Datum) Min(Datum)

  Alt 14. Mai 2013, 15:23
Hi,
ja das hab ich auch schon probiert. (wurde in einem vorherigen Post auch schon vorgeschlagen)
Liefert mir aber auch nicht das was ich brauch.
Es hat so viele gute Ratschläge gegeben welchen hast Du ausprobiert?

Was mir auffällt (ich kann aber auch etwas übsehen haben)
Code:
 LEFT OUTER JOIN FEHLTAGEDEFINITION ftd
    ON bd.Fehltag = ftd.Kuerzel
wofür soll das gut sein?
(Nützt nix schad aber auch nicht gilt hier nicht)

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
Metallicwar

Registriert seit: 5. Feb 2010
Ort: Bad Kissingen
293 Beiträge
 
Delphi XE Architect
 
#5

AW: Max(Datum) Min(Datum)

  Alt 14. Mai 2013, 15:57
Zitat:
Es hat so viele gute Ratschläge gegeben welchen hast Du ausprobiert?
--> Jeden ...

Zitat:
Was mir auffällt (ich kann aber auch etwas übsehen haben)
[CODE]
LEFT OUTER JOIN FEHLTAGEDEFINITION ftd
ON bd.Fehltag = ftd.Kuerzel

wofür soll das gut sein?
(Nützt nix schad aber auch nicht gilt hier nicht)
--> Diesen JOIN benötige ich, um herauszufinden, ob der Mitarbeiter an diesem Tag z.B. Krank ist oder Urlaub hat.


Hab zunächst mal den Tipp aus Beitrag #8 probiert. Hat mir leider auch nicht weitergeholfen, hab so nur jeden Eintrag doppelt angezeigt bekommen ... bin jetzt aber schon ein Stückchen weiter...
Ich hab lediglich das ORDER BY am Ende umgebaut.
Die Ergebnismenge war die ganze Zeit "fast" richtig, nur falsch sortiert ....
Code:
SELECT ma_s.ID, ma_s.Personalnummer as Personalnr, ma_s.Nachname as Name,
       ma_s.Vorname, bd.Datum, bd.Kuerzel, bd.Feiertag, a.Bezeichnung,
       IIF(be.Pause = 0, null, ZMIF.MinToHour(be.Pause)) AS PauseH,
       ZMIF.MinToIHour(be.Pause) as PauseIH,
       IIF(be.Tagesbrutto = 0, null, ZMIF.MinToHour(be.Tagesbrutto)) AS TagesbruttoH,
       ZMIF.MinToIHour(be.Tagesbrutto) as TagesbruttoIH,
       IIF(be.Mehrarbeit = 0, null, ZMIF.MinToHour(be.Mehrarbeit)) AS MehrarbeitH,
       ZMIF.MinToIHour(be.Mehrarbeit) as MehrarbeitIH, b.BuchungsArt,
       min(b.Me1) as Me1,
       max(b.Me2) as Me2, b.Flag
  FROM MA_Stammdaten ma_s
  LEFT OUTER JOIN Abteilungen a
    ON ma_s.ID_Abteilungen = a.ID
  LEFT OUTER JOIN Buchungsdatei bd
    ON ma_s.ID = bd.ID_MA_Stammdaten
  LEFT OUTER JOIN Buchungen b
    ON bd.ID_MA_Stammdaten = b.ID_MA_Stammdaten
   AND bd.Datum = b.Datum and b.BuchungsArt = 'A'
  LEFT OUTER JOIN FEHLTAGEDEFINITION ftd
    ON bd.Fehltag = ftd.Kuerzel
  LEFT OUTER JOIN B_Ergebnisse be
    ON bd.ID = be.ID_Buchungsdatei
 WHERE ma_s.ID IN (3)
   and Month(bd.Datum) = 2
   and Year(bd.Datum) = 2013 
 GROUP BY 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 18
UNION ALL
SELECT ma_s.ID, ma_s.Personalnummer as Personalnr, ma_s.Nachname as Name,
       ma_s.Vorname, bd.Datum, bd.Kuerzel, bd.Feiertag, a.Bezeichnung,
       IIF(be.Pause = 0, null, ZMIF.MinToHour(be.Pause)) AS PauseH,
       ZMIF.MinToIHour(be.Pause) as PauseIH,
       IIF(be.Tagesbrutto = 0, null, ZMIF.MinToHour(be.Tagesbrutto)) AS TagesbruttoH,
       ZMIF.MinToIHour(be.Tagesbrutto) as TagesbruttoIH,
       IIF(be.Mehrarbeit = 0, null, ZMIF.MinToHour(be.Mehrarbeit)) AS MehrarbeitH,
       ZMIF.MinToIHour(be.Mehrarbeit) as MehrarbeitIH, b.BuchungsArt,
      b.Me1, b.Me2, b.Flag        
  FROM MA_Stammdaten ma_s
  LEFT OUTER JOIN Abteilungen a
    ON ma_s.ID_Abteilungen = a.ID
  LEFT OUTER JOIN Buchungsdatei bd
    ON ma_s.ID = bd.ID_MA_Stammdaten
  LEFT OUTER JOIN Buchungen b
    ON bd.ID_MA_Stammdaten = b.ID_MA_Stammdaten
   AND bd.Datum = b.Datum and b.BuchungsArt <> 'A'
  LEFT OUTER JOIN FEHLTAGEDEFINITION ftd
    ON bd.Fehltag = ftd.Kuerzel
  LEFT OUTER JOIN B_Ergebnisse be
    ON bd.ID = be.ID_Buchungsdatei
 WHERE ma_s.ID IN (3)
   and Month(bd.Datum) = 2
   and Year(bd.Datum) = 2013
ORDER BY bd.Datum, ma_s.ID
Letzte Problem vor dem ich jetzt steh ist folgendes:
- An Wochenenden hat er pro Tag zwei Datensätze ...
Wenn man den Screenshot im Anhang betrachtet sieht man, dass er jetzt nur noch das min/max aus 'A' Buchungen bildet und alle anderen Buchungen alles anzeigt ...

Ich schau mir das heute Abend nochmal in Ruhe an und werd mich morgen wieder melden.
Angehängte Grafiken
Dateityp: png kommtgeht.png (16,0 KB, 5x aufgerufen)
  Mit Zitat antworten Zitat
Benutzerbild von baumina
baumina

Registriert seit: 5. Mai 2008
Ort: Oberschwaben
1.275 Beiträge
 
Delphi 11 Alexandria
 
#6

AW: Max(Datum) Min(Datum)

  Alt 15. Mai 2013, 06:59
[QUOTE=Metallicwar;1215325]
Zitat:
--> Diesen JOIN benötige ich, um herauszufinden, ob der Mitarbeiter an diesem Tag z.B. Krank ist oder Urlaub hat.
Auf ftd wird nur niemals zugegriffen, weder im select noch im where.
  Mit Zitat antworten Zitat
Benutzerbild von Olli73
Olli73

Registriert seit: 25. Apr 2008
Ort: Neunkirchen
782 Beiträge
 
#7

AW: Max(Datum) Min(Datum)

  Alt 14. Mai 2013, 14:47
Hab die Bedingung für die BuchungsArt nun in den Join gepackt (oben "and b.BuchungsArt = 'A' und unten "and b.BuchungsArt = 'P' wobei ich immmernoch der Meinung bin, dass ich hier "and b.BuchungsArt <> 'A' schreiben muss.
BuchungsArt <> 'A' ist natürlich richtig, wenn es neben 'P' noch weitere Arten gibt, die einzeln angezeigt werden sollen.

==> In meinem Ergebnis werden jetzt aber wieder nur die Buchungen mit Buchungsart "A" angezeigt
Teste doch mal die beiden SQL-Teile (vor/nach UNION) getrennt.

Macht meiner Meinung nach keinen Sinn, im max/min Select zu prüfen ob die BuchungsArt 'P' ist, dann werden die 'A' Buchungen genullt und immer noch max/min von 'P' Buchungen angezeigt.
Das 'P' ist ja auch ein (getarntes) 'A'

Kollege hat mir vorgeschlagen, mit einem CASE zu arbeiten ?!?
Ein Case ist im Prinzip auch nix anderes als ein IIF?! (keine Ahnung, ob ADS beides unterstützt)

Evtl. solltest/musst du auch noch Beitrag #8 beachten.
  Mit Zitat antworten Zitat
Benutzerbild von baumina
baumina

Registriert seit: 5. Mai 2008
Ort: Oberschwaben
1.275 Beiträge
 
Delphi 11 Alexandria
 
#8

AW: Max(Datum) Min(Datum)

  Alt 14. Mai 2013, 15:05
Ich verzweifel langsam an diesem SQL ...
Oh ja, das kann ich sehr gut nachvollziehen. Da hilft jetzt echt nur noch eins, du musst quasi von vorne beginnen und wie Olli73 auch schon vorgeschlagen hat, die selects auf jeden Fall erstmal getrennt anschauen und dann nicht gleich mit allen joins, sondern alles Schritt für Schritt aufbauen.

In meinen Anfangszeiten habe ich meine Chefs immer dafür gehasst, wenn sie mir sagten, wirf erstmal alles weg und machs neu, aber da ist echt was dran.
  Mit Zitat antworten Zitat
Antwort Antwort


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 19:04 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-2025 by Thomas Breitkreuz