AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Sub-Select im Haupt-Select: lässt sich dann "group by" anwenden?
Thema durchsuchen
Ansicht
Themen-Optionen

Sub-Select im Haupt-Select: lässt sich dann "group by" anwenden?

Offene Frage von "Rainbow6"
Ein Thema von juergen · begonnen am 8. Jul 2020 · letzter Beitrag vom 8. Jul 2020
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von juergen
juergen

Registriert seit: 10. Jan 2005
Ort: Bönen
1.174 Beiträge
 
Delphi 11 Alexandria
 
#1

Sub-Select im Haupt-Select: lässt sich dann "group by" anwenden?

  Alt 8. Jul 2020, 13:15
Datenbank: MSSQL • Version: 2017 • Zugriff über: SQL
Hallo zusammen,

ist es möglich bei einem verwendeten Sub-Select eine "group by"-Klausel anzuwenden und wenn ja wie müsste das aussehen?
Ich konnte da auf die Schnelle nichts finden.

An den 2 Stellen wo die Fragezeichen sind komme ich nicht weiter

Code:
SELECT
   MAX(BN.TOTAL_STD),
   (SELECT
         CA.NAME + ', ' + CA.VORNAME + ' (' + LTRIM(PERSNR) + ')'
      FROM PERSONALSTAMM CA
      WHERE
         CA.IDENTIFIKATION = BN.PERSREC_ID)
   AS Person,
   BN.DATUM
FROM ZEITRUECKMELDUNGEN BN
GROUP BY BN.TOTAL_STD,
         ?????,
         BN.DATUM
ORDER BY ?????, BN.DATUM
Vielen Dank schon mal vorab!
Jürgen
Indes sie forschten, röntgten, filmten, funkten, entstand von selbst die köstlichste Erfindung: der Umweg als die kürzeste Verbindung zwischen zwei Punkten. (Erich Kästner)
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.624 Beiträge
 
Delphi 12 Athens
 
#2

AW: Sub-Select im Haupt-Select: lässt sich dann "group by" anwenden?

  Alt 8. Jul 2020, 13:24
Die Nicht-Aggregat-Felder heißen ja Person und BN.Datum, danach sollte sich eigentlich gruppieren lassen, oder habe ich etwas übersehen?
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von juergen
juergen

Registriert seit: 10. Jan 2005
Ort: Bönen
1.174 Beiträge
 
Delphi 11 Alexandria
 
#3

AW: Sub-Select im Haupt-Select: lässt sich dann "group by" anwenden?

  Alt 8. Jul 2020, 13:59
Wenn ich anstelle der Fragezeichen "Person" eintrage zeigt mir das SSMS folgendes an:

Zitat:
Ungültiger Spaltenname "Person".
In der Group by Klausel scheint MSSQL den Alias "Person" nicht zu kennen, bzw. ich weiß also nicht wie ich es richtig bezeichnen muss an der Stelle.
Jürgen
Indes sie forschten, röntgten, filmten, funkten, entstand von selbst die köstlichste Erfindung: der Umweg als die kürzeste Verbindung zwischen zwei Punkten. (Erich Kästner)
  Mit Zitat antworten Zitat
Delphi.Narium

Registriert seit: 27. Nov 2017
2.490 Beiträge
 
Delphi 7 Professional
 
#4

AW: Sub-Select im Haupt-Select: lässt sich dann "group by" anwenden?

  Alt 8. Jul 2020, 14:13
SQL-Code:
select Max(TOTAL_STD) as TOTAL_STD, Person, Datum
from
(
  SELECT
     BN.TOTAL_STD,
     (SELECT
           CA.NAME + ', ' + CA.VORNAME + ' (' + LTRIM(PERSNR) + ')'
        FROM PERSONALSTAMM CA
        WHERE
           CA.IDENTIFIKATION = BN.PERSREC_ID)
     AS Person,
     BN.DATUM
  FROM ZEITRUECKMELDUNGEN BN
) x
GROUP BY Person,
         Datum
ORDER BY 2, 3
SQL-Code:
SELECT
   MAX(BN.TOTAL_STD),
   (SELECT
         CA.NAME + ', ' + CA.VORNAME + ' (' + LTRIM(PERSNR) + ')'
      FROM PERSONALSTAMM CA
      WHERE
         CA.IDENTIFIKATION = BN.PERSREC_ID)
   AS Person,
   BN.DATUM
FROM ZEITRUECKMELDUNGEN BN
GROUP BY CA.NAME + ', ' + CA.VORNAME + ' (' + LTRIM(PERSNR) + ')',
         BN.DATUM
ORDER BY 2, 3
SQL-Code:
SELECT
   MAX(BN.TOTAL_STD),
   CA.NAME + ', ' + CA.VORNAME + ' (' + LTRIM(PERSNR) + ')AS Person,
   BN.DATUM
FROM ZEITRUECKMELDUNGEN BN,
     PERSONALSTAMM CA
WHERE CA.IDENTIFIKATION = BN.PERSREC_ID
GROUP BY CA.NAME + ', ' + CA.VORNAME + ' (' + LTRIM(PERSNR) + ')',
         BN.DATUM
ORDER BY 2, 3
SQL-Code:
SELECT
   MAX(BN.TOTAL_STD),
   CA.NAME + ', ' + CA.VORNAME + ' (' + LTRIM(PERSNR) + ')AS Person,
   BN.DATUM
FROM ZEITRUECKMELDUNGEN BN
inner join PERSONALSTAMM CA on CA.IDENTIFIKATION = BN.PERSREC_ID
GROUP BY CA.NAME + ', ' + CA.VORNAME + ' (' + LTRIM(PERSNR) + ')',
         BN.DATUM
ORDER BY 2, 3
Es gibt bestimmt noch weitere Varianten.

Geändert von Delphi.Narium ( 8. Jul 2020 um 14:31 Uhr) Grund: Fehler im Group by behoben (siehe Post Uwe weiter unten)
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.624 Beiträge
 
Delphi 12 Athens
 
#5

AW: Sub-Select im Haupt-Select: lässt sich dann "group by" anwenden?

  Alt 8. Jul 2020, 14:14
Anderer Ansatz:
SQL-Code:
SELECT
   MAX(BN.TOTAL_STD),
   (CA.NAME + ', ' + CA.VORNAME + ' (' + LTRIM(PERSNR) + ')') AS Person,
   BN.DATUM
FROM ZEITRUECKMELDUNGEN BN
JOIN
  PERSONALSTAMM CA ON CA.IDENTIFIKATION = BN.PERSREC_ID
GROUP BY CA.NAME, CA.VORNAME, PERSNR, BN.DATUM
ORDER BY CA.NAME, CA.VORNAME, PERSNR, BN.DATUM
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.453 Beiträge
 
Delphi 12 Athens
 
#6

AW: Sub-Select im Haupt-Select: lässt sich dann "group by" anwenden?

  Alt 8. Jul 2020, 14:20
MAX(BN.TOTAL_STD) und GROUP BY BN.TOTAL_STD passt irgendwie nicht zusammen.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von juergen
juergen

Registriert seit: 10. Jan 2005
Ort: Bönen
1.174 Beiträge
 
Delphi 11 Alexandria
 
#7

AW: Sub-Select im Haupt-Select: lässt sich dann "group by" anwenden?

  Alt 8. Jul 2020, 14:44
Danke schon mal für die Antworten!!

Folgendes lässt sich ohne Syntaxfehler aufrufen:
Code:
SELECT
   MAX(BN.TOTAL_STD),
   CA.NAME + ', ' + CA.VORNAME + ' (' + LTRIM(PERSNR) + ')' AS Person,
   BN.DATUM
FROM ZEITRUECKMELDUNGEN BN,
    PERSONALSTAMM CA
WHERE
   CA.IDENTIFIKATION = BN.PERSREC_ID
GROUP BY BN.TOTAL_STD,
       CA.NAME + ', ' + CA.VORNAME + ' (' + LTRIM(PERSNR) + ')',
       BN.DATUM
ORDER BY 2, 3
Das war auch mein erster Ansatz.

ABER:
Dabei werden mir pro Person und pro Tag *mehrere* Zeilen ausgegeben.
Ich will erreichen, dass pro Tag nur eine Zeile ausgegeben wird und zwar die mit dem höchsten Wert bei BN.TOTAL_STD. Da hatte ich gehofft, dass
Code:
MAX(BN.TOTAL_STD)
ausreicht.
Das tuts aber leider nicht.

Meine Kern-Frage ist also:
Wie erhalte ich mit dem hier gezeigtem SQL nur eine Zeile pro Tag und pro Person, jeweils die Zeile, wo der Wert bei "BN.TOTAL_STD" am höchsten ist.

Deswegen hatte ich es mit Subselect probiert, weiß aber nicht ob das überhaupt der richtige Ansatz ist.
Jürgen
Indes sie forschten, röntgten, filmten, funkten, entstand von selbst die köstlichste Erfindung: der Umweg als die kürzeste Verbindung zwischen zwei Punkten. (Erich Kästner)
  Mit Zitat antworten Zitat
Benutzerbild von mikhal
mikhal

Registriert seit: 11. Sep 2003
Ort: Linz am Rhein
796 Beiträge
 
Delphi 11 Alexandria
 
#8

AW: Sub-Select im Haupt-Select: lässt sich dann "group by" anwenden?

  Alt 8. Jul 2020, 14:51
Was hindert dich daran, BN.PERSREC_ID als Feld aufzunehmen und danach als erstes zu gruppieren?
Die Gruppierung des Feldes BN.TOTAL_STD solltest du löschen.

Grüße
Mikhal
Michael Kraemer
Computer erleichtern die Arbeit...
...und die Erde ist eine Scheibe!
  Mit Zitat antworten Zitat
Delphi.Narium

Registriert seit: 27. Nov 2017
2.490 Beiträge
 
Delphi 7 Professional
 
#9

AW: Sub-Select im Haupt-Select: lässt sich dann "group by" anwenden?

  Alt 8. Jul 2020, 14:54
SQL-Code:
SELECT
   MAX(BN.TOTAL_STD),
   CA.NAME + ', ' + CA.VORNAME + ' (' + LTRIM(PERSNR) + ')AS Person,
   BN.DATUM
FROM ZEITRUECKMELDUNGEN BN,
    PERSONALSTAMM CA
WHERE
   CA.IDENTIFIKATION = BN.PERSREC_ID
GROUP BY
       -- BN.TOTAL_STD, Uwe hat schon drauf hingewiesen, dass das falsch ist
       CA.NAME + ', ' + CA.VORNAME + ' (' + LTRIM(PERSNR) + ')',
       BN.DATUM
ORDER BY 2, 3
  Mit Zitat antworten Zitat
Benutzerbild von juergen
juergen

Registriert seit: 10. Jan 2005
Ort: Bönen
1.174 Beiträge
 
Delphi 11 Alexandria
 
#10

AW: Sub-Select im Haupt-Select: lässt sich dann "group by" anwenden?

  Alt 8. Jul 2020, 15:53
Dankeschön!

, Ok für das genannte Beispiel passt das nun wenn ich "BN.Total_Std" weg lasse in der Group-Klausel.
Ich hatte auf Uwes Hinweis deswegen nicht reagiert, weil ich aus Nichtwissen davon ausgegangen war, dass in der Group by-Klausel immer alle Spalten enthalten sein müssen die im Select stehen. Da muss ich mich wohl noch etwas schlauer machen.

Nun, das gezeigte SQL war "natürlich" nur ein Ausschnitt.

Jetzt habe ich folgendes (immer noch reduziertes) SQL Statement:

Code:
SELECT
   SELECT
        MAX(BN.TOTAL_STD),
   CA.NAME + ', ' + CA.VORNAME + ' (' + LTRIM(PERSNR) + ')',
   BA.AUFTRAGTEXT, -- <-- diese Zeile bewirkt, dass mehrere Zeilen pro Mitarbeiter und pro Tag angezeigt werden !   
   BN.DATUM,
   SQ.KOMMENTAR,
   B_zwei.ABTBEZEICHNUNG,
   DATEPART(wk, CONVERT(VARCHAR(8), BN.DATUM, 112)) "KW",
   1 "Zähler"
FROM ZEITRUECKMELDUNGEN BN
LEFT JOIN KTORECHWERTE SW ON BN.PERSREC_ID = SW.PERSID
      AND CONVERT(VARCHAR(8), SW.DATUM, 112) = BN.DATUM
LEFT JOIN KTORECHANZWERTE SQ ON SW.DEFINITIONID = SQ.IDENTIFIKATION
LEFT JOIN PERSONALSTAMM CA ON BN.PERSREC_ID = CA.IDENTIFIKATION
LEFT JOIN AUFTRAGSTAMM BA ON BN.AUFTRAGSNUMMER = BA.AUFTRAGSNR COLLATE Latin1_General_BIN
LEFT JOIN ABTEILUNG B_zwei ON CA.ABTEILUNG = B_zwei.ABTEILUNGNR
WHERE
   BN.DATUM >= '2019-01-01'
   AND BN.DATUM <= '2020-07-01'
   AND BN.TOTAL_STD <> '   0.00'
   AND SW.DEFINITIONID IN (413, 414, 415)
   AND SW.WERT > 0
   AND BN.STATUS_BEGINN IN ('N', 'E')
GROUP BY CA.NAME + ', ' + CA.VORNAME + ' (' + LTRIM(PERSNR) + ')',
       BA.AUFTRAGTEXT,
       BN.DATUM,
       SQ.KOMMENTAR,
       B_zwei.ABTBEZEICHNUNG
ORDER BY CA.NAME + ', ' + CA.VORNAME + ' (' + LTRIM(PERSNR) + ')',
BN.DATUM
Hiermit werden nun wieder mehrere Zeilen pro Tag und pro Person angezeigt. Wenn ich BA.AUFTRAGTEXT entferne funktioniert alles und es wird nur eine Zeile pro Tag und Pro Person ausgewiesen.
Kann mir hier nochmal jemand auf die Sprünge helfen?
Jürgen
Indes sie forschten, röntgten, filmten, funkten, entstand von selbst die köstlichste Erfindung: der Umweg als die kürzeste Verbindung zwischen zwei Punkten. (Erich Kästner)
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 02:22 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