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, 9006 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
Microsoft Office

MS Office Excel - Formel wird angezeigt, aber nicht berechneter Wert!

Tipp von holli.zimmi zum Thema Microsoft Office ...

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

Frage von H41mSh1C0R zum Thema Datenbanken ...

Datenbanken
gelöst Hilfe bei SQL-Abfrage (5)

Frage von emeriks zum Thema Datenbanken ...

Windows Server
SQL Server sichern in Azure (2)

Frage von xxlukasxx zum Thema Windows Server ...

Windows Server
gelöst SQL Server 2016 User CALs auch für ältere SQL-Server-Version nutzbar? (3)

Frage von Jeiko71 zum Thema Windows Server ...

Heiß diskutierte Inhalte
Hyper-V
gelöst Reiner Hyper- V Server oder lieber Rolle (15)

Frage von Winuser zum Thema Hyper-V ...

Windows Server
gelöst Rechte als Admin vergeben - Zugriff verweigert (14)

Frage von Ghost108 zum Thema Windows Server ...

Router & Routing
gelöst IP Kamera für drei unabhängige Netzwerke (12)

Frage von ProfessorZ zum Thema Router & Routing ...