Paco: SELECT/JOIN/SQL-statement richtig formulieren

Beitrag lesen

jeder hat ja seinen stil, wie man abschreiben erstellt, aber bei diese darstellung ist schon nicht einfach zu lesen. nur als tipp gemeint, versuche mal eine andere darstellung, auch aliasnamen helfen immens.

Ups, da is die Formatierung beim copy-pasten flöten gegangen, sorry.

nun aber zu der eigentlichen frage, diese abfrage kann so nicht funktionieren, du unterliegst einem mysql bug. dafür gibt es mittlerweile soviel postings hier im forum über diesen "bug", dass wir mysql eine rechnung stellen sollten. du gibst die spalten "rolle" aus, ohne darüber gruppiert zu haben.

Was ist denn nun genau der Bug? Die Abfrage funktioniert doch. Und was meinst du mit ausgeben ohne vorher zu gruppieren?

das andere ist, du machst auf die tabelle "dispo", die du vorher mit einem OUTER LEFT JOIN eingebunden hast, zusätzlich danach noch einen INNER JOIN auf eine die tabelle "rollen". das macht keinen sinn, weill du dann wieder datensätze verlieren kannst, die du durch den LEFT JOIN eigentlich haben wolltest.

Ich dachte mir das so: tabelle projekte>=tabelle dispo>=users=rolle. Also benutzer/rolle als "kleinster gemeinsamer Nenner", bzw als Teilmenge von dispo, dispo als teilmenge von projekte. Welche datensätze verliere ich denn da?

und um dein problem zu lösen, dass du Datensätze als spalten darstellen willst, das geht, wenn du die Anzahl der Spalten genau weisst, sprich eine spalte für technik, eine für grafik .... also bekannt und endlich sind. dazu kannst du korrelierte unterabfragen benutzen. unterabfragen bei mysql gehen aber erst ab version 4.1. und da du uns version verschwiegen hast....

Meine Serverversion ist 5.0. Also dann werde ich mich mal mit den korrelierten unterabfragen auseinandersetzen...

Vielen Dank schonmal