SilentDemise Geschrieben 25. Januar 2011 Teilen Geschrieben 25. Januar 2011 Hallo zusammen, ich hab ein kleines Problem mit MySQL bei dem ich einfach nicht weiterkomme. Ich bin in einem Brownfield Projekt und muss mit einer bestehenden Datenbank arbeiten, die mir momentan etwas Kopfzerbrechen bereitet. Die beiden Tabellen die meine Abfrage betrifft sind wie folgt Strukturiert Tabelle teilnehmer: id - Name - Standort - Thema_Id - Abteilung Tabelle Thema: id - Titel - Standort - aktiv Mein Ziel ist nun folgendes: Ich brauche ein SQL Statement das mir die Titel aller Themen auflistet und dabei die Anzahl der Teilnehmer zählt, wo die Themen Id gleich dem Thema ist. Außerdem wird meiner PHP Funktion der Standort und die Abteilung übergeben. Mein Versuch sieht bisher so aus: SELECT Thema.titel AS thema, COUNT( teilnehmer.id ) AS zahl FROM Thema, Teilnehmer WHERE Thema.Standort = '11' (Standorte immer 2 stellig) OR Thema.Standort = '0' (0 steht für übergreifende Themen) AND Teilnehmer.Thema_Id = Thema.Id AND Teilnehmer.Abteilung LIKE '110' (abteilung sind 5, Stelle 4 un5 interessieren für die Abfrage nicht) GROUP BY thema Ich hoffe ich konnte klar machen, was ich möchte. Der obige Code funktioniert jedenfalls nicht, wahrscheinlich habe ich einen Denkfehler :/ Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
lupo49 Geschrieben 25. Januar 2011 Teilen Geschrieben 25. Januar 2011 Deine Abfrage funktioniert syntaktisch vermutlich nicht, weil bei GROUP BY eine Spalte anzugeben ist. SELECT tm.Titel, COUNT(tn.ID) FROM Thema tm LEFT JOIN Teilnehmer tn ON tm.id = tn.ID GROUP BY tm.Titel Was würde dann dabei als Ergebnis herauskommen? Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
SilentDemise Geschrieben 25. Januar 2011 Autor Teilen Geschrieben 25. Januar 2011 Hallo Lupo, vielen dank schonmal für deine Hilfe. Syntaktisch funkioniert meine Abfrage, jedoch bekomme ich in jeder Zeile das Thema und als Count wert immer die Gesamtzahl der Einträge der Tabelle Teilnehmer, sprich ca. so: Outlook - 1000 Windows - 1000 Word - 1000 1000 ist beispielhaft die Gesamtzahl der Einträge in der Tabelle Teilnehmer. Seltsamerweise bekomme ich ein anderes Ergebnis, wenn ich die letzte WHERE clause weglasse. (AND Teilnehmer.Abteilung LIKE '110') da bekomme ich unterschiedliche werte für jedes Thema. Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
dr.dimitri Geschrieben 25. Januar 2011 Teilen Geschrieben 25. Januar 2011 WHERE [B][COLOR=red]([/COLOR][/B]Thema.Standort = '11' (Standorte immer 2 stellig) OR Thema.Standort = '0' [B][COLOR=red])[/COLOR][/B] (0 steht für übergreifende Themen) Zum einen eine vergessene Klammer, und dann noch das LIKE. Laut Kommentar fehlt ein %: AND Teilnehmer.Abteilung LIKE '110[B][COLOR=red]%[/COLOR][/B]' Dim Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
lupo49 Geschrieben 26. Januar 2011 Teilen Geschrieben 26. Januar 2011 Wieso sind denn die Bedingungen der OR-Verknüpfung in Klammern zu schreiben? Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
SilentDemise Geschrieben 26. Januar 2011 Autor Teilen Geschrieben 26. Januar 2011 Das OR in Klammern zu schreiben hat tatsächlich ein Stück weit geholfen. Kann ich mir sogar ganz gut erklären. In Programmiersprachen ist es meist so das AND stärker ist als OR und er also zuerst alle ANDS auswertet und den Wert vor dem OR mit den AND verknüpften Werten erst danach. oO Obs so nun passt muss ich erstmal testen, bin zumindest schonmal nen Schritt weiter. Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Empfohlene Beiträge
Dein Kommentar
Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.