SELECT Wert einer Tabelle, der nicht in einer anderen ist

Einklappen
X
 
  • Filter
  • Zeit
  • Anzeigen
Alles löschen
neue Beiträge

  • SELECT Wert einer Tabelle, der nicht in einer anderen ist

    Hi,

    ich möchte von meiner MySQL-Tabelle alle Felder einer Tabelle haben, deren Werte nicht in einer anderen (ähnlichen) Tabelle sind.

    Es sind zwei Tabellen vorhanden:

    table1: id,name

    table2: id,name

    Also alle Felder von table1 sollen zurückgegeben werden, wo der Wert von "name" nicht in table2 vorhanden ist.

    Wie realisiere ich das?

    Mein Versuch:

    PHP-Code:
    $qry mysql_query("SELECT id,name FROM `table1`
                        WHERE name NOT IN (SELECT name FROM `table2`)"
    );
    if(
    mysql_num_rows($qry) != 0)
    {
        echo 
    "Mindestens ein Feld nicht in table2 vorhanden!";

    hat nicht funktioniert. Da wird nichts ausgegeben.

    Vielen Dank für eure Hilfe
    Boron

  • #2
    http://www.php-resource.de/forum/sho...threadid=28292

    ^^ schau dir die beispiele an
    Kissolino.com

    Kommentar


    • #3
      Ja....

      Aber bei mir sind die ids nicht gleich.

      Kannst du mir bitte sagen, wie es richtig heißen muss?

      Kommentar


      • #4
        Eine dritte Tabelle erstellen die die Schlüssel beider Tabellen beinhaltet (siehe http://www.php-resource.de/forum/sho...threadid=71539) und dadrauf dann eine SQL-Anweisung absetzen. Nur das du hier nicht mir "="-Operator sondern "!="-Operator arbeitest.

        Kommentar


        • #5
          Hi,

          vielen Danken für deine Antwort.

          Eine dritte Tabelle erstellen die die Schlüssel beider Tabellen beinhaltet
          Muss ich eine weitere Tabelle erstellen? Oder komm ich da nicht drumrum?

          Kommentar


          • #6
            Das folgende Beispiel im mysql Manual suchen und anpassen (wenn ich die Frage richtig verstehe: Alle Datensätze finden, .....)
            PHP-Code:
            SELECT table1.* FROM table1
              LEFT JOIN table2 ON table1
            .id=table2.id
              WHERE table2
            .id IS NULL
            PS die mysql-Formulierung in der Frage scheint zutreffend, ausser wenn t2.name=NULL vorkommt. Ansonsten mysql_error() ? var_dump(mysql_num_rows..)) ?
            Zuletzt geändert von mai; 09.06.2006, 23:08.

            Kommentar


            • #7
              PHP-Code:
              // Leute, die nicht mehr in der Mitgliederliste sind
              $qry mysql_query("SELECT t1.id,
                                         t1.nachname AS nachname,
                                         t1.vorname AS vorname
                                  FROM "
              .$table["leute"]." AS t1
                                  LEFT JOIN "
              .$table["mitglieder"]." AS t2 
                                    ON t1.nachname=t2.nachname AND t1.vorname=t2.vorname
                                  WHERE t2.nachname IS NULL
                                  "
              );
              echo 
              mysql_errno() . ": " mysql_error() . "\n"
              gibt

              1267: Illegal mix of collations (latin1_german2_ci,IMPLICIT) and (latin1_general_ci,IMPLICIT) for operation '='
              zurück.

              Was tun?

              Wie gesagt, die Ids sind unterschiedlich - ich kann die zwei Tabellen halt nur anhand der Werte, die in den Feldern nachname und vorname vorkommen, überprüfen.

              edit: Ach bin ich blöd, dann sollte ich natürlich die zwei Kollationen gleichsetzen.... danke!

              Btw, welche Kollation sollte man nehmen? Die Namen werden eh urlencoded gespeichert.

              So funktioniert es jedenfalls. Vielen Dank.
              Zuletzt geändert von Boron; 10.06.2006, 10:42.

              Kommentar

              Lädt...
              X