Werte gehen verloren

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

  • 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

    Comment


    • #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

      Comment


      • #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

        Comment


        • #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.
          Last edited by 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!

          Comment


          • #6
            Originally posted by Kropff View Post
            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

            Originally posted by 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.

            Originally posted by 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

            Comment


            • #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!

              Comment


              • #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.?

                Comment

                Working...
                X