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.