Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit
GELÖST

SQL-Statement .. Ausruck ist nicht Teil der Aggregatfunktion

Frage Entwicklung Datenbanken

Mitglied: Jochem

Jochem (Level 2) - Jetzt verbinden

24.08.2012 um 09:26 Uhr, 8654 Aufrufe, 2 Kommentare

Moin zusammen,

ich brech mir hier gerade bei einer Access-Anwendung mit SQL-Statements die Ohren.

01.
SELECT Sum(WBZ.Anzahl), WBZ.WBZNr, WBZ.Str, HNR.Nam, WBZ.Hnr, HNR.HnrZus, HNR.Lon, HNR.Lat, HNR.Str 
02.
FROM WBZ, HNR 
03.
WHERE ([WBZ.Str]=[HNR.Str]) AND ([WBZ.Hnr]=[HNR.HnrZus]) 
04.
GROUP BY [WBZ.WBZNr] 
05.
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
Mitglied: LianenSchwinger
24.08.2012, aktualisiert um 09:41 Uhr
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:

01.
SELECT WBZ.WBZNr, 
02.
       Sum(WBZ.Anzahl) AS Anzahl 
03.
FROM WBZ, HNR  
04.
WHERE ([WBZ.Str]=[HNR.Str]) AND ([WBZ.Hnr]=[HNR.HnrZus])  
05.
GROUP BY [WBZ.WBZNr]  
06.
ORDER BY [WBZ.WBZNr];
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
Bitte warten ..
Mitglied: Jochem
24.08.2012, aktualisiert um 11:02 Uhr
Moin,

Hallo Jörg,

Tja, so rum wird ein Schuh draus:

>>Du musst alle Felder die nicht mittels einer Aggregat Funktion (SUm, Min, MAX, ...) ermittelt werden in die Group By Klausel aufnehmen <<

Dann kann ich ja lange testen, *puuuh*.

Der Vergleich von Hnr und HnrZus ist schon ok so: in der HNR gibt es zwei Felder Hnr und Zusatz, die ich im Feld HnrZus zusammengeführt habe und in der WBZ nur das Feld Hnr.

Ich teste mich da jetz mal weiter ran. Danke.

Gruß J chem

EDIT: Jep, hat funktioniert. Ich habe jetzt die Summe per Bezirk einzeln ausgewertet und in einer weiteren Aktion die Tabellen dann noch einmal entsprechend meinen Vorgaben verknüpft.
Bitte warten ..
Neuester Wissensbeitrag
Windows 10

Powershell 5 BSOD

(8)

Tipp von agowa338 zum Thema Windows 10 ...

Ähnliche Inhalte
Datenbanken
gelöst SQL Statement auseinandernehmen Like (20)

Frage von H41mSh1C0R zum Thema Datenbanken ...

Datenbanken
gelöst SQL-Abfrage - DISTINCT - letztes Datum (3)

Frage von emeriks zum Thema Datenbanken ...

Verschlüsselung & Zertifikate
Kryptorätsel Teil 1: Die Geheimschrift für Liebende (2)

Link von netzwerker-92 zum Thema Verschlüsselung & Zertifikate ...

Windows Server
gelöst SQL-Server Datenbanksicherung inkl. Benutzerberechtigungen dafür? (4)

Frage von 1410640014 zum Thema Windows Server ...

Heiß diskutierte Inhalte
Microsoft
Ordner mit LW-Buchstaben versehen und benennen (20)

Frage von Xaero1982 zum Thema Microsoft ...

Outlook & Mail
gelöst Outlook 2010 findet ost datei nicht (19)

Frage von Floh21 zum Thema Outlook & Mail ...

Netzwerkmanagement
gelöst Anregungen, kleiner Betrieb, IT-Umgebung (18)

Frage von Unwichtig zum Thema Netzwerkmanagement ...

Festplatten, SSD, Raid
M.2 SSD wird nicht erkannt (14)

Frage von uridium69 zum Thema Festplatten, SSD, Raid ...