Einzelnen Beitrag anzeigen

Benutzerbild von sx2008
sx2008

Registriert seit: 16. Feb 2008
Ort: Baden-Württemberg
2.332 Beiträge
 
Delphi 2007 Professional
 
#12

AW: SQL : select mit Fallabfrage

  Alt 22. Jun 2013, 01:39
Wie soll ich denn sonst an meine Sum(Anzahl) kommen wenn nicht über GROUP BY?
Ohne GROUP BY wird natürlich auch eine Summe gebildet und zwar die Summe über alle Datensätze die durch die WHERE-Bedingung angesprochen werden.
Vereinfacht gesagt wird ohne GROUP BY alles in einen Topf summiert.
Mit GROUP BY können mehrere Töpfe (=Datensätze) entstehen wobei jeder Topf seine eigene Teilsumme hat.

Beispieltabelle
Code:
Farbe  | Preis
==================
rot    | 5.0
grün   | 10.0
blau   | 15.0
rot    | 22.0
SQL-Code:
SELECT Sum(Preis) FROM Beispieltabelle
-- Ergebnis: 1 Datensatz Inhalt: 52.0
SQL-Code:
SELECT Sum(Preis) FROM Beispieltabelle
GROUP BY Farbe
-- Ergebnis: 3 Datensätze Inhalt:
-- 15.0
-- 10.0
-- 27.0
Man sieht aber dass diese Ergebnistabelle ziemlich sinnlos ist weil der Bezug zu dem Group-By-Feld verloren gegangen ist.
Deshalb sind die Felder aus der Group-By-Klausel eigentlich immer in der Feldliste enthalten:
SQL-Code:
SELECT Farbe, Sum(Preis) FROM Beispieltabelle
GROUP BY Farbe
-- Ergebnis: 3 Datensätze Inhalt:
-- blau | 15.0
-- grün | 10.0
-- rot | 27.0
Würde man jetzt alle diese Teilsummen aufsummieren dann kommt man wieder auf die Gesamtsumme von 52.0.
fork me on Github
  Mit Zitat antworten Zitat