SQL-Statement .. Ausruck ist nicht Teil der Aggregatfunktion
Moin zusammen,
ich brech mir hier gerade bei einer Access-Anwendung mit SQL-Statements die Ohren.
Gegeben sind zwei Tabellen: HNR enthält Strassen, Hausnummern und Koordinaten; WBZ enthält Bezirke, Strassen, Hausnummern und Personenanzahl pro Hausnummer. Alle Felder bis auf "Anzahl" sind vom Typ "Text", Anzahl ist vom Typ "Integer".
Es sollen nun beide Tabellen so kombiniert werden, daß pro Bezirk (sortiert nach Strasse und Hausnummer) die Summe der Personen ausgeworfen wird.
Leider laufe ich bisher jedesmal in den "Ausdruck xxxx ist nicht Teil der Aggregatfunktion"-Fehler. Packe ich eines der als "Ausdruck" definierten Felder mit in die ORDER BY oder GROUP BY Klausel, so wird das nächste Feld angemeckert. Schlußendlich möchte ich aber die Ausgabe nur nach der Bezirksnummer gruppiert haben und nicht noch nach diversen anderen Feldern.
Eigenartig ist, daß bei der Fehlermeldung nur der Spaltenname erscheint, ohne die Zuordnung zur Tabelle, also "Nam" anstelle von HNR.Nam". Ich vermute fast, daß es mit den gleichlautenden Spaltenbezeichnern in beiden Tabellen etwas zu tun hat, aber in der Abfrage definiere ich sie ja mit "Tabellen-Name.Spalten-Name". Von daher sollte alles im grünen Bereich liegen.
Was mache ich falsch bzw. wo liegt mein Denkfehler?
Gruß J chem
ich brech mir hier gerade bei einer Access-Anwendung mit SQL-Statements die Ohren.
SELECT Sum(WBZ.Anzahl), WBZ.WBZNr, WBZ.Str, HNR.Nam, WBZ.Hnr, HNR.HnrZus, HNR.Lon, HNR.Lat, HNR.Str
FROM WBZ, HNR
WHERE ([WBZ.Str]=[HNR.Str]) AND ([WBZ.Hnr]=[HNR.HnrZus])
GROUP BY [WBZ.WBZNr]
ORDER BY [WBZ.Str], [WBZ.Hnr];
Gegeben sind zwei Tabellen: HNR enthält Strassen, Hausnummern und Koordinaten; WBZ enthält Bezirke, Strassen, Hausnummern und Personenanzahl pro Hausnummer. Alle Felder bis auf "Anzahl" sind vom Typ "Text", Anzahl ist vom Typ "Integer".
Es sollen nun beide Tabellen so kombiniert werden, daß pro Bezirk (sortiert nach Strasse und Hausnummer) die Summe der Personen ausgeworfen wird.
Leider laufe ich bisher jedesmal in den "Ausdruck xxxx ist nicht Teil der Aggregatfunktion"-Fehler. Packe ich eines der als "Ausdruck" definierten Felder mit in die ORDER BY oder GROUP BY Klausel, so wird das nächste Feld angemeckert. Schlußendlich möchte ich aber die Ausgabe nur nach der Bezirksnummer gruppiert haben und nicht noch nach diversen anderen Feldern.
Eigenartig ist, daß bei der Fehlermeldung nur der Spaltenname erscheint, ohne die Zuordnung zur Tabelle, also "Nam" anstelle von HNR.Nam". Ich vermute fast, daß es mit den gleichlautenden Spaltenbezeichnern in beiden Tabellen etwas zu tun hat, aber in der Abfrage definiere ich sie ja mit "Tabellen-Name.Spalten-Name". Von daher sollte alles im grünen Bereich liegen.
Was mache ich falsch bzw. wo liegt mein Denkfehler?
Gruß J chem
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 190125
Url: https://administrator.de/contentid/190125
Ausgedruckt am: 21.11.2024 um 20:11 Uhr
2 Kommentare
Neuester Kommentar
Hallo Jochem,
Du musst alle Felder die nicht mittels einer Aggregat Funktion (SUm, Min, MAX, ...) ermittelt werden in die Group By Klausel aufnehmen und wenn Du nur die Anzahl pro Bezirk haben willst kannst Du nicht noch die anderen Felder hinzunehmen.
In Deinem Fall heiß das:
Wobei die Verknüpfung [WBZ.Hnr]=[HNR.HnrZus] aus meiner Sicht noch nicht ganz stimmen kann (Hausnummer zu HausnummerZusatz?).
Wenn Du die Straßen und Hausnummern sowie eine Gesamt Summenzeile haben möchtest musst Du Dich mit CUBE bzw. ROLLUP in der Group By Klausel auseinandersetzen.
Gruß Jörg
Du musst alle Felder die nicht mittels einer Aggregat Funktion (SUm, Min, MAX, ...) ermittelt werden in die Group By Klausel aufnehmen und wenn Du nur die Anzahl pro Bezirk haben willst kannst Du nicht noch die anderen Felder hinzunehmen.
In Deinem Fall heiß das:
SELECT WBZ.WBZNr,
Sum(WBZ.Anzahl) AS Anzahl
FROM WBZ, HNR
WHERE ([WBZ.Str]=[HNR.Str]) AND ([WBZ.Hnr]=[HNR.HnrZus])
GROUP BY [WBZ.WBZNr]
ORDER BY [WBZ.WBZNr];
Wenn Du die Straßen und Hausnummern sowie eine Gesamt Summenzeile haben möchtest musst Du Dich mit CUBE bzw. ROLLUP in der Group By Klausel auseinandersetzen.
Gruß Jörg