Werte gehen verloren

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

  • Werte gehen verloren

    Hallo,

    ich habe mich hier angemeldet, da ich hoffe, dass mir hier jemand helfen kann. Und zwar habe ich eine MySQL-Datenbank mit 3 Tabellen:

    - Laender
    - Städte
    - Details

    Und diese Einträge sind miteinander verknüpft, soll heißen wenn ich bei Laender Deutschland auswähle, kommen nur Deutsche Städte, wenn ich Stuttgart auswähle bekomme ich einen Text mit Details zu Stuttgart.

    Das Land und die Stadt werden per Dropdown-Menü ausgewählt, das 2. Menü läd sich automatisch mit den entsprechenden Inhalten je nachdem, was in Menü 1 ausgewählt wurde. Wenn ich mir die Datenbank so ansehen möchte, funktioniert das, da ich dort nur den letzten Wert brauche, bzw.
    die letzte ID (die der Stadt, die Städte und Länder sind per IDS verknüpft).

    Wenn ich nun eine neue Stadt einfügen möchte, brauche ich aber auch die ID des Landers (lid), die wird mir eigentlich als Ergebnis des ersten Dropdown Menüs geliefert. Jedoch geht der Wert immer verloren, obwohl ich ihn in eine Session-Variable speicher:

    PHP-Code:
    <?php
     session_start
    ();
    ?>
    <title>Einfügen</title>
    <head></head>
    <body>

    <?php
    echo "<form action='' target='_self' method='post' name='drop1' target='_self'>";

            
    mysql_connect("localhost","root","") or die ("Fehler beim Verbinden mit der Datenbank.");
            
    mysql_select_db("klassenarbeiten") or die ("Fehler beim Öffnen der Datenbank");

            echo 
    "<p>";
            echo 
    "<select name='menu1'>";
            echo 
    "<option value=''>Bitte w&auml;hen...</option>";

            
    $query "SELECT * FROM Laender";
            
    $ergebnis mysql_query($query) or die ("mysql_error()");

            while(
    $row mysql_fetch_array($ergebnis))
            {
             echo 
    "<option value='".$row["lid"]."'>".$row["Land"]."</option>";
            }

            echo 
    "</select>";
            echo
    "<input type='hidden' name='PHPSESSID' value='<?=session_id()?>'>";
            echo
    "<input type='submit' name='fertig1' value='Bestaetigen' size ='20' />";
            echo 
    "</p>";


            echo 
    "</form>";

             if(isset(
    $_POST['fertig1']))
             {
              
    $_SESSION["ergebnis1"] = $_POST["menu1"];
             }

             echo 
    "<form action='' target='_self' method='post' name='drop2' target='_self'>";


             echo 
    "<p>";
             echo 
    "<select name='menu2'>";
             echo 
    "<option value=''>Bitte w&auml;hen...</option>";

             
    $query "SELECT * FROM Staedte INNER JOIN faecher ON themen.lid = faecher.lid WHERE faecher.lid = '{$_POST['menu1']}'";
             
    $ergebnis mysql_query($query) or die ("mysql_error()");

             while(
    $row mysql_fetch_array($ergebnis))
             {
              echo 
    "<option value='".$row["sid"]."'>".$row["Stadt"]."</option>";
             }
             echo 
    "</select>";
             echo
    "<input type='hidden' name='PHPSESSID' value='<?=session_id()?>'>";
             echo
    "<input type='submit' name='fertig2' value='Bestaetigen' size ='20' />";
             echo 
    "</p>";

            echo 
    "</form>";

             if(isset(
    $_POST['fertig2']))
             {
              
    $_SESSION["ergebnis2"] = $_POST["menu2"];
              
    $lid $_SESSION['ergebnis1'];
              
    $sid $_SESSION['ergebnis2'];
              echo 
    $_SESSION['ergebnis1'];
              echo 
    $_SESSION['ergebnis2'];
             }

            
    //. . .
    ?>
    </body>
    </html>
    Danke schonmal im voraus! :S

  • #2
    Auf den ersten Blick sieht das ganz ok aus. Ich frage mich nur, was das mit dem hidden-Feld soll. Warum arbeitest du nicht mit der Konstante SID? Die übernimmt das automatisch. Hast du dir mal die Werte in den hidden-Feldern angesehen? "<?=" funktioniert nicht immer.

    Peter
    Nukular, das Wort ist N-u-k-u-l-a-r (Homer Simpson)
    Meine Seite

    Kommentar


    • #3
      Also das mit dem Hidden-Feld war ein Lösungsversuch^^
      Es hat davor auch nicht getan und in einer Anleitung stand,
      dass man dieses Feld einbauen soll, wenn der Wert erhalten bleiben soll,
      hat aber weder davor noch danach funktioniert...

      Und als Fehlemeldung bekomme ich undefined index ergebnis1

      Kommentar


      • #4
        Und was steht in den hidden-Feldern? Ist der Wert dort korrekt?

        Peter
        Nukular, das Wort ist N-u-k-u-l-a-r (Homer Simpson)
        Meine Seite

        Kommentar


        • #5
          Dein Problem ist aber nicht einfach nur, dass die gewählten Werte nach Absenden nicht im entsprechenden Select-Feld wieder automatisch angewählt sind?

          EDIT:
          Die Notice 'undefined index ergebnis1 ' wird wohl nur ausgegeben, wenn du das zweite Form absendest, ohne zuvor das erste abgesendet zu haben.
          Zuletzt geändert von Quetschi; 06.02.2012, 12:00.
          Ihr habt ein Torturial durchgearbeitet, das auf den mysql_-Funktionen aufbaut?
          Schön - etwas Geschichte kann ja nicht schaden.
          Aber jetzt seht euch bitte php.net/pdo oder php.net/mysqli bevor ihr beginnt!

          Kommentar


          • #6
            Zitat von Kropff Beitrag anzeigen
            Und was steht in den hidden-Feldern? Ist der Wert dort korrekt?

            Peter
            Wie überprüfe ich dass den? Und woran erkenne ich denn, dass der Wert stimmt? Sorry, bin Anfänger :S

            Zitat von Quetschi
            Dein Problem ist aber nicht einfach nur, dass die gewählten Werte nach Absenden nicht im entsprechenden Select-Feld wieder automatisch angewählt sind?

            Peter
            Die Frage verstehe ich nicht. Das Problem ist, dass in diesem Codesegment:
            PHP-Code:

                     
            if(isset($_POST['fertig1']))
                     {
                      
            $_SESSION["ergebnis1"] = $_POST["menu1"];
                     } 
            Das Ergebnis vom 1. Dropdown-Menü nicht in die Session-Variable kopiert wird, sobald der Submit-Button gedrückt wurde, bzw. ist die Variable auch leer das weiß ich nicht.Wenn ich weiter unten die Variable ausgeben möchte:
            PHP-Code:
                            echo $_SESSION['ergebnis1']; 
            Bekomme ich undefined index ergebnis1.

            Zitat von Quetschi
            EDIT:
            Die Notice 'undefined index ergebnis1 ' wird wohl nur ausgegeben, wenn du das zweite Form absendest, ohne zuvor das erste abgesendet zu haben.
            Nein, das ergibt ja überhaupt keinen Sinn. Das 2. Dropdown-Menü ist ja noch völlig leer, wenn ich im 1. nichts ausgewählt habe.

            Mit freundlichen Grüßen

            Kommentar


            • #7
              Hab deinen Code mal eben ohne DB angetestet und das funktioniert soweit:

              PHP-Code:
              <?php

              error_reporting
              (E_ALL);
              ini_set('display_errors'1);  

               
              session_start();
               
              ?>
              <title>Einfügen</title>
              <head></head>
              <body>

              <?php
              echo "<form action='' target='_self' method='post' name='drop1' target='_self'>";


                      echo 
              "<p>";
                      echo 
              "<select name='menu1'>";
                      echo 
              "<option value=''>Bitte w&auml;hen...</option>";

                       echo 
              "<option value='1'>BlaBla</option>";
                       echo 
              "<option value='2'>BluBlu</option>";

                      echo 
              "</select>";
                      echo
              "<input type='hidden' name='PHPSESSID' value='<?=session_id()?>'>";
                      echo
              "<input type='submit' name='fertig1' value='Bestaetigen' size ='20' />";
                      echo 
              "</p>";


                      echo 
              "</form>";

                       if(isset(
              $_POST['fertig1']))
                       {
                        
              $_SESSION["ergebnis1"] = $_POST["menu1"];
                       }

                       echo 
              "<form action='' target='_self' method='post' name='drop2' target='_self'>";


                       echo 
              "<p>";
                       echo 
              "<select name='menu2'>";
                       echo 
              "<option value=''>Bitte w&auml;hen...</option>";

                        echo 
              "<option value='1'>lala</option>";
                        echo 
              "<option value='2'>lulu</option>";

                       echo 
              "</select>";
                       echo
              "<input type='hidden' name='PHPSESSID' value='<?=session_id()?>'>";
                       echo
              "<input type='submit' name='fertig2' value='Bestaetigen' size ='20' />";
                       echo 
              "</p>";

                      echo 
              "</form>";

                       if(isset(
              $_POST['fertig2']))
                       {
                        
              $_SESSION["ergebnis2"] = $_POST["menu2"];
                        
              $lid $_SESSION['ergebnis1'];
                        
              $sid $_SESSION['ergebnis2'];
                        echo 
              $_SESSION['ergebnis1'];
                        echo 
              $_SESSION['ergebnis2'];
                       }


              ?>
              </body>
              </html>
              Ihr habt ein Torturial durchgearbeitet, das auf den mysql_-Funktionen aufbaut?
              Schön - etwas Geschichte kann ja nicht schaden.
              Aber jetzt seht euch bitte php.net/pdo oder php.net/mysqli bevor ihr beginnt!

              Kommentar


              • #8
                Oh mein Gott jetzt funktioniert es!
                Danke für den Hinweis, alles was ich tun musste war session_unset();
                in die if-Bedingung reinzupacken. Aber eine Frage noch: Also wenn es daran
                lag, dann wurde ja die Sitzung immer gleich wieder gelöscht. Warum ging
                aber dann nur der 1. Wert verloren und nicht auch der 2.?

                Kommentar

                Lädt...
                X