Announcement

Collapse
No announcement yet.

Frage zu LeftJoin Abfrage

Collapse
X
  • Filter
  • Time
  • Show
Clear All
new posts

  • Frage zu LeftJoin Abfrage

    Guten Abend,

    ich habe da eine Frage zu einer gewissen LeftJoin Abfrage in MySQL, ich bekomm es einfach nicht hin die passende Ergebnismenge zu bekommen. Also erstmal ein wenig Vorwissen über meine Datenbankstruktur:

    Tabelle Position:
    Standort | Objekt_1 | Objekt_2 | Objekt_3 | Typ | Bemerkung

    Tabelle Verbindungen:
    Von_Standort | Von_1 | Von_2 | Von_3 | Nach_Standort | Nach_1 | Nach_2 | Nach_3

    Also in der Tabelle "Position" liegen meine Stammdaten, also alle verfügbaren Daten. In der Tabelle Verbindungen werden diese einzelnen Daten miteinandern verknüft, in meinem Fall Switch Verbindungen zu einer Raumdose oder von Switch zu Switch bzw. Raumdose zu Raumdose.

    Das ganze verwalte ich mit einem in Java geschriebenen Programm, dort benutze ich verschiedene Joins um die passenden Ergebnismengen zu bekommen. Nun zu meinem Problem. Ich möchte gerne durch einen Left Join alle Daten aus den Spalten Objekt_1 bis Objekt_3 bekommen, die sich noch nicht in der Tabelle Verbindungen befinden (in den Spalten: Von_1 bis Von_3 und Nach_1 bis Nach_3).

    Ein Beispiel:
    Wenn in der Tabelle Verbindungen folgendes steht:
    null;4507;3;4;null;31;C;12
    dann möchte ich meiner Ergebnismenge alle Daten aus der Position Tabelle bekommen, außer die oben im Beispiel genannten, da diese schon vergeben sind bzw. belegt.

    Mein Ansatz sieht derzeit so aus:
    [highlight=sql]SELECT Position.Objekt_1, Position.Objekt_2, Position.Objekt_3, Verbindungen.Von_1, Verbindungen.Von_2, Verbindungen.Von_3, Verbindungen.Nach_1, Verbindungen.Nach_2, Verbindungen.Nach_3 From Position LEFT JOIN Verbindungen ON Position.Objekt_3 = Verbindungen.Von_3 AND Position.Objekt_3 = Verbindungen.Nach_3 AND Verbindungen.Von_2 = Position.Objekt_2 AND Verbindungen.Nach_2 = Position.Objekt_2 And Position.Objekt_1 = Verbindungen.Von_1 AND Position.Objekt_1 = Verbindungen.Nach_1 Where (Verbindungen.Von_3 is NULL OR Verbindungen.Nach_3 is NULL) AND Position.Objekt_1 = '4507';[/highlight]

    Problem daran ist, wenn jetzt z.B. der obere Datensatz folgendermaßen aussieht:
    null;31;C;12null;4507;3;4;

    Also vertauscht, so bekomme ich als Ergebnismenge immer noch die 4507;3;4, obwohl diese eigentlich belegt ist.

    Ich hoffe jemand kann mir dabei helfen.

    Mfg,

    Strece
    Zuletzt editiert von Strece; 30.09.2010, 14:08.

  • #2
    Bitte beachten: Formatierung von SQL in Beiträgen
    Wenn du denkst du hast alle Bugs gefunden, dann ist das ein Bug in deiner Denksoftware.

    Quellcode ohne ein Mindestmaß an Formatierung sehe ich mir nicht an! Ich leiste keinen Privatsupport per Mail oder PN!

    Comment


    • #3
      Ok werd ich ändern, habe nun aber schon eine Lösung gefunden:
      [highlight=sql]SELECT Position.Standort,
      Position.Objekt_1,
      Position.Objekt_2,
      Position.Objekt_3,
      Position.Typ,
      Position.Bemerkung
      FROM Position LEFT JOIN Verbindungen
      ON (Position.Objekt_3 = Verbindungen.Von_3
      AND Position.Objekt_2 = Verbindungen.Von_2
      AND Position.Objekt_1 = Verbindungen.Von_1)
      OR (Position.Objekt_3 = Verbindungen.Nach_3
      AND Position.Objekt_2 = Verbindungen.Nach_2
      AND Position.Objekt_1 = Verbindungen.Nach_1)
      WHERE Verbindungen.Von_3 IS NULL AND Verbindungen.Nach_3 IS NULL;[/highlight]

      Mfg, Strece

      Comment

      Working...
      X