Top-Themen

Aktuelle Themen (A bis Z)

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 MS Access SQL-Abfrage mit bedingter Gruppierung

Mitglied: Oehioehi

Oehioehi (Level 1) - Jetzt verbinden

05.12.2010 um 12:53 Uhr, 8203 Aufrufe, 3 Kommentare

Bin neu in diesem freundlichen Forum und habe mein Problem bisher noch nirgends diskutiert gesehen und hoffe, daß jemand helfen kann.

ich möchte mit MSAccess 2007 eine SQL Abfrage bauen, welche mir Sätze bedingt gruppiert.

Tabellenstruktur ist in etwa folgende:

Name Umsatz StadtDatensatzID
Meier 2000Hamburg 4711
Meier 3000München 4712
Müller 4000Gelsenkirchen 4713
Müller 2000Lübeck 4714
Müller 1000Kaiserslautern 4715
Müller 1000Bochum 4716
Schulze 2000Berlin 4718
Schulze 1000Dresden 4719
Schulze 1000Leipzig 4720


Ausgegeben werden soll mir die Summe pro Name nur dann, wenn mehr als 3 Datensätze pro Name vorhanden sind.
Andernfalls sollen mir die die Sätze einzeln gezeigt werden.

Also folgendermaßen:

NameUmsatz
Meier2000
Meier3000
Müller8000
Schulze 2000
Schulze 1000
Schulze 1000

Danke soweit,
ich hoffe die Fragestellung ist plausibel!
Mitglied: NetWolf
05.12.2010 um 19:09 Uhr
Moin Moin,

und willkommen im Forum.

So wie ich das sehe, hinkt dein Beispiel an mehren Ecken.
Da werden Namen summiert, die nichts miteinander zu tun haben = unterschiedliche Städte. Wenn es Filialen eines Hauptsitzes sein sollten, ist das nicht ersichtlich = z.B durch eine entsprechende ID.

Mit SQL kannst du das was da ist auswerten. Da hier wichtige Informationen fehlen, ist imho dein Wunsch nicht zu erfüllen.
D.h. du musst erst mal eine Basis schaffen, auf der eine entsprechende Auswertung möglich ist. Also z.B. eine ID der zusammengehörigen Firmen und dann noch eine ID für die Niederlassungen.

Füge ein zusätzliches Feld für die Gruppierung hinzu, z.B. Anzahl_Niederlassungen.
Per VBA durchläufst du nun die Daten und mit DCOUNT zählst du wie viele Niederlassungen der Firma in der Tabelle vorhanden sind.

Ist DCOUNT nun größer als 3 kommt in das Feld Anzahl_Niederlassungen pauschal eine z.B. 99 (oder auch die echte Anzahl)
Ist DCOUNT nun kleiner als 3 kommt in jeden Datensatz eine entsprechende Zahl die du einfach hoch zählst = 1,2,3

Mit dieser Information kannst du nun deine Datensätze gruppieren.

Deinem Beispiel folgend wäre dann der Datenbestand:
1 Meier
2 Meier
99 Müller
99 Müller
99 Müller
99 Müller
1 Schulze
2 Schulze
3 Schulze

Verwendest du nun den Namen (besser eine entsprechende ID) und den Zähler, steht einer Gruppierung nach deinem Wunsch nichts im Wege.
Beides in EINE SQL-Abfrage zu packen funktioniert nicht, da die nötigen Informationen für die Gruppierung dann zu spät zur Verfügung stehen würden.

Grüße aus Rostock
Wolfgang
(Netwolf)
Bitte warten ..
Mitglied: Oehioehi
05.12.2010 um 20:26 Uhr
Vielen Dank für die schnelle Antwort!
Ich verstehe was Du meinst und hast mich mit DCount und der 99 auf die richtige Idee gebracht. Ich denke, das auch mit einer Unterabfrage bewerkstelligen zu können.
Werde in der kommenden Woche hier hoffentlich die Lösung posten!

Schöne Grüße aus dem schneevermatschten Hamburg,
Peter
Bitte warten ..
Mitglied: Oehioehi
10.12.2010 um 17:52 Uhr
Hallo Netwolf,
habe das Problem mit Hilfe Deines Tipps wie folgt gelöst:

Die erste Abfrage nennt sich

ErmitteltAnzahlStaedte

SELECT TabelleMitarbeiterUmsatz.Name, Count(TabelleMitarbeiterUmsatz.Stadt) AS AnzahlvonStadt
FROM TabelleMitarbeiterUmsatz
GROUP BY TabelleMitarbeiterUmsatz.Name;

Mit der zweiten Abfrage nehme ich Bezug auf die Anzahl der ermittelten Städte:

SELECT TabelleMitarbeiterUmsatz.Name, Sum(TabelleMitarbeiterUmsatz.Umsatz) AS SummevonUmsatz
FROM TabelleMitarbeiterUmsatz INNER JOIN ErmitteltAnzahlStaedte ON TabelleMitarbeiterUmsatz.Name = ErmitteltAnzahlStaedte.Name
GROUP BY TabelleMitarbeiterUmsatz.Name, IIf([anzahlvonstadt]>3,"9999" & [ermitteltanzahlstaedte].[name],[id] & [ermitteltanzahlstaedte].[name]);

Voila!
Bitte warten ..
Ähnliche Inhalte
Entwicklung
MS SQL 2008: Abfrage in Datei speichern
gelöst Frage von StephanCEntwicklung6 Kommentare

Hallo Zusammen, ich soll jeden Tag zu einer bestimmten Uhrzeit diverse Daten in einer Datei zur Verfügung stellen. Die ...

Datenbanken

MS SQL Abfragen und Formulare in Webseite einbinden

gelöst Frage von MachelloDatenbanken3 Kommentare

Hallo Zusammen, ich habe eine grundlegende Frage: System: MS - SQL Server mit einer relationalen Datenbank SQL-Express 2016 (Eine ...

Datenbanken

MS SQL - Zwei Summierungen (für Vergleich) in einer Abfrage möglich?

gelöst Frage von BluejetDatenbanken3 Kommentare

Hallo zusammen, es ist sicher ein einfaches Unterfangen, jedoch weiß ich nicht, wie ich es im Moment lösen soll ...

Datenbanken

MS Access - SQL Datenbank - Alle SPalten werden mit GELÖSCHT angezeigt

Frage von harald.schmidtDatenbanken1 Kommentar

Hallo Leute. Ich habe folgendes Problem: - SQL Server 2016 - eine db - paar tabellen - greifen darauf ...

Neue Wissensbeiträge
Sicherheit

MikroTik-Router patchen, Schwachstelle wird ausgenutzt

Information von kgborn vor 9 StundenSicherheit

Am 23. April 2018 wurde von Mikrotik ein Security Advisory herausgegeben, welches auf eine Schwachstelle im RouterOS hinwies. Mikrotik ...

Windows 10

Microcode-Updates KB4090007, KB4091663, KB4091664, KB4091666 für Windows 10

Information von kgborn vor 15 StundenWindows 101 Kommentar

Kurze Information für Administratoren von Windows 10-Systemen, die mit neueren Intel CPUs laufen. Microsoft hat zum 23. April 2018 ...

iOS
Updates für Iphone und Co
Information von sabines vor 19 StundeniOS

Gestern abend ist iOS 11.3.1 erschienen, ein kleineres Update, dass einige Lücken schließt und "Lahmlegen" nach einem Display Tausch ...

Windows 7

Windows 7 - Server 2008 R2: Exploit für Total Meltdown verfügbar

Information von kgborn vor 2 TagenWindows 7

Kleine Information für Administratoren, die für die Updates von Windows 7 SP1 und Windows Server 2008 R2 SP1 verantwortlich ...

Heiß diskutierte Inhalte
Batch & Shell
Powershell: Im AD nach Rechnern mit bestimmten IP-Adressen suchen
gelöst Frage von Raven42Batch & Shell36 Kommentare

Hallo zusammen, ich suche nach einer Möglichkeit nach Computern im AD zu suchen , deren IP-Adresse mit 10.11.12. beginnt. ...

C und C++
Frage1 C Programmierung-Makefile Frage2 PHP-Programmierung HTTP-Fehler 404
Frage von KatalinaC und C++34 Kommentare

Hallo, ich habe 2 Fragen, die nichts miteinander zu tun haben aber mit denen ich mich gerade beschäftige: 1. ...

LAN, WAN, Wireless
Watchguard T15 VPN Einrichtung
gelöst Frage von thomasjayLAN, WAN, Wireless25 Kommentare

Hallo zusammen, wir möchten gerne über unsere Watchguard T15 einen VPN-Tunnel (Mobile VPN with IPSec) einrichten! Als Client nutzen ...

Windows Server
Alten DC entfernen
Frage von smartinoWindows Server24 Kommentare

Hallo zusammen, ich habe hier eine Umgebung übernommen und erstmal einen DCDIAG gemacht. Dabei fällt auf, daß eine ganze ...