Kalle: MySQL Abfrage über 2 Tabellen

Hilfe,

irgendwie habe ich heute ein Brett vor dem Kopf. Ich möchte freie Stunden für eine Person ermitteln.

In Tabelle "vorh" sind die auf einer Veranstaltung verfügbaren Stunden eines Stundenplans:

std
---
1
2
3
4
5

in Tabelle "verg" die bereits für 300 Personen vergebenen:

pers std
---- ---
4711 2
4711 4
4712 2
4712 5
...

Für Person 4711 sind also die Stunden 1, 3 und 5 noch verfügbar

select vorh.std
from   vorh, verg
where  vorh.std != verg.std AND verg.pers = 4711

ergibt alle möglichen Stunden.

Wo ist mein Denkfehler?

LIebe Grüße aus Worms, Kalle

  1. Hallo!

    In Tabelle "vorh" sind die auf einer Veranstaltung verfügbaren Stunden eines Stundenplans:

    std

    1
    2
    3
    4
    5

    in Tabelle "verg" die bereits für 300 Personen vergebenen:

    pers std


    4711 2
    4711 4
    4712 2
    4712 5
    ...

    Wo ist mein Denkfehler?

    Der Denkfehler ist, daß Du Dir nicht alle Stunden anzeigen zu läßt, die es nicht in der Tabelle "verg" gibt.

    Schaue Dir mal nach und nach die Ergebnisse der SQL-Statements an.

    // 1.
    SELECT vorh.std FROM vorh LEFT JOIN verg ON (vorh.std=verg.std);

    // 2.
    SELECT vorh.std FROM vorh LEFT JOIN verg ON (vorh.std=verg.std) WHERE verg.pers=4711;

    // 3.
    SELECT vorh.std FROM vorh LEFT JOIN verg ON (vorh.std=verg.std) WHERE verg.pers=4711 AND verg.std IS NULL;

    MfG, André Laugks

    --
    L-Andre @ gmx.de
    1. Hallo André,

      Der Denkfehler ist, daß Du Dir nicht alle Stunden anzeigen zu läßt, die es nicht in der Tabelle "verg" gibt.

      Schaue Dir mal nach und nach die Ergebnisse der SQL-Statements an.

      // 1.
      SELECT vorh.std FROM vorh LEFT JOIN verg ON (vorh.std=verg.std);

      // 2.
      SELECT vorh.std FROM vorh LEFT JOIN verg ON (vorh.std=verg.std) WHERE verg.pers=4711;

      // 3.
      SELECT vorh.std FROM vorh LEFT JOIN verg ON (vorh.std=verg.std) WHERE verg.pers=4711 AND verg.std IS NULL;

      Fall 3 zeigt kein Ergebnis. Sorry, der erhoffte Lerneffekt ist ausgeblieben.

      Aber immerhin: Ich hatte ein WHERE vor dem JOIN. Weil das eine Fehlermeldung gab, dachte ich, WHERE und JOIN schließen sich aus. Ich brauche ein gutes Nachschlagewerk.

      Lieben Gruß, Kalle

      1. Hallo!

        // 3.
        SELECT vorh.std FROM vorh LEFT JOIN verg ON (vorh.std=verg.std) WHERE verg.pers=4711 AND verg.std IS NULL;

        Fall 3 zeigt kein Ergebnis. Sorry, der erhoffte Lerneffekt ist ausgeblieben.

        Ich hatte es ungetestet geschrieben:

        SELECT vorh.std FROM vorh LEFT JOIN verg ON (vorh.std=verg.std AND verg.pers=4711) WHERE verg.std IS NULL;

        Das (... verg.pers=4711) im ON steht ist IMHO nach Standard nicht korrekt, funktioniert aber.

        Wenn Du die Tabelle folgendemaßen erweiterst, also was eine Person absolute an Stunden haben kann...

        std    pers
        ---
        1      4711
        2      4711
        3      4711
        4      4711
        5      4711
        1      4711
        2      4711
        3      4711
        4      4711
        5      4711

        geht es auch so:

        SELECT vorh.std, vorh.pers, verg.std, verg.pers
        FROM vorh LEFT JOIN verg ON (vorh.std=verg.std AND vorh.pers=verg.pers) WHERE vorh.pers=4711 AND verg.std IS NULL;

        MfG, André Laugks

        --
        L-Andre @ gmx.de
  2. yo,

    irgendwie habe ich heute ein Brett vor dem Kopf. Ich möchte freie Stunden für eine Person ermitteln.

    einen outer join über NULL abfragen.

    SELECT std FROM vorh LEFT JOIN verg ON (vorh.std=verg.std)
    WHERE verg.std IS NULL;

    Ilja