• Jetzt anmelden. Es dauert nur 2 Minuten und ist kostenlos!

Frage Daten via php in Mysql Datenbank speichern

Black_Anon

Neues Mitglied
Hallo, ich habe folgendes Problem:

ich möchte eingegebene Daten in einer MySQL Datenbank speichern.
Das auslesen und connecten der datenbank funktioniert. Jedoch das beschreiben nicht.

Ich benutze im php folgenden Code:
PHP:
if($_POST["passwort"] == $_POST["passwort2"])
                {
                    $eintrag = "INSERT INTO mitarbeiter (name, vorname, passwort, geburtsdatum, strasse, plz, e-mail, telefon, admin, ahv, lohn, gruppe) VALUES ('$name', '$vorname', '$passwort', '$geburtsdatum', '$strasse', '$plz', '$email', '$telefon', '$admin', '$ahv', '$lohn', '$gruppe')";
                    mysql_query($eintrag);
                    echo '<script type="text/javascript" language="Javascript">  alert("Benutzer wurde erfolgreich eingetragen!") </script> <meta http-equiv="refresh" content="0; URL=useradd.php">';
                }

was mache ich da falsch das es nichts reinschreibt?
 
Werbung:
1. Du benutzt noch die veraltete MySQL-Extension, anstatt MySQLi
2. Du schreibst Tabellen und Spaltennamen nicht zwischen Backticks `
3. Du fragst nicht die Datenbank, was schief gelaufen ist, Stichwort mysqli_error
4. Du schreibst ins falsche Board, das ist ein PHP- und kein HTML-Problem
 
Werbung:
Das ist das Formular:
PHP:
<?php
session_start();
?>

<?php
if(!isset($_SESSION["id"]))
  {
    echo '<script type="text/javascript" language="Javascript">  alert("Bitte loge dich zuerst ein!") </script> <meta http-equiv="refresh" content="0; URL=index.html">'; 
  }
  else
  {
    $id = ($_SESSION["id"]);
    $verbindung = mysql_connect("localhost", "planung" , "*************")
    or die("Verbindung zur Datenbank konnte nicht hergestellt werden");
    mysql_select_db("planung") or die ("Datenbank konnte nicht ausgewählt werden");
   
    $abfrage = "SELECT * FROM mitarbeiter WHERE id LIKE '$id'";
    $ergebnis = mysql_query($abfrage);
    while($row = mysql_fetch_object($ergebnis))
        {
            if($row->admin == 5)
            {   
                echo '
                <link rel="stylesheet" href="style.css">
                <div align="center">
                    <div id="profilkasten">
                        <div id="links">
                            <a href="profil.php">Profil</a><br>
                            <a href="homepage">Hinzuf&uuml;gen</a><br>
                            <a href="homepage">Abrufen</a><br>
                            <a href="passwort.php">Passwort &auml;ndern</a><br>
                            <a href="admin.php">Administration</a><br>
                            <a href="logout.php">Logout</a>
                        </div>
                        <form action="useradd2.php" method="post">
                        <table id="tabelleprofil">
                        <tr>
                            <td>' . $row->name . '</td>
                            <td>' . $row->vorname . '</td>
                        </tr>
                        <tr>
                            <td>Name:</td>
                            <td><input type="text" size="24" maxlength="50" name="name"></td>
                        </tr>
                        <tr>
                            <td>Vorname:</td>
                            <td><input type="text" size="24" maxlength="50" name="vorname"></td>
                        </tr>
                        <tr>
                            <td>Passwort:</td>
                            <td><input type="password" size="24" maxlength="50" name="passwort"></td>
                        </tr>
                        <tr>
                            <td>Passwort wiederholen:</td>
                            <td><input type="password" size="24" maxlength="50" name="passwort2"></td>
                        </tr>
                        <tr>
                            <td>Geburtsdatum:</td>
                            <td><input type="text" size="24" maxlength="50" name="geburtsdatum"></td>
                        </tr>
                        <tr>
                            <td>Strasse:</td>
                            <td><input type="text" size="24" maxlength="50" name="strasse"></td>
                        </tr>
                        <tr>
                            <td>PLZ/Ort:</td>
                            <td><input type="text" size="24" maxlength="50" name="plz"></td>
                        </tr>
                        <tr>
                            <td>E-Mail:</td>
                            <td><input type="text" size="24" maxlength="50" name="email"></td>
                        </tr>
                        <tr>
                            <td>Telefon:</td>
                            <td><input type="text" size="24" maxlength="50" name="telefon"></td>
                        </tr>
                        <tr>
                            <td>Administrator:</td>
                            <td><select name="admin">
                                <option>0</option>
                                <option>1</option>
                                <option>2</option>
                                <option>3</option>
                                <option>4</option>
                                <option>5</option>
                            </select></td>
                        </tr>
                        <tr>
                            <td>0 = keine Adminrechte</td>
                        </tr>
                        <tr>
                            <td>AHV-Nummer:</td>
                            <td><input type="text" size="24" maxlength="50" name="ahv"></td>
                        </tr>
                        <tr>
                            <td>Lohn:</td>
                            <td><select name="lohn">
                                <option>21.50</option>
                                <option>25.00</option>
                                <option>30.00</option>
                                <option>35.00</option>
                            </select></td>
                        </tr>
                        <tr>
                            <td>Gruppe:</td>
                            <td><select name="gruppe">
                                <option>0</option>
                                <option>1</option>
                                <option>2</option>
                                <option>3</option>
                            </select></td>
                        </tr>
                        <tr>
                            <td><input type="submit" value="Benutzer hinzuf&uuml;gen"></td>
                            <td></td>
                        </tr>
                        </table>
                        </form>
                    </div>
                </div>';
            }
            else
            {
                echo '<script type="text/javascript" language="Javascript">  alert("Du bist kein Administrator!") </script> <meta http-equiv="refresh" content="0; URL=profil.php">';
            }
        }
  }
?>

Und das Die Speicherung:
PHP:
<?php
session_start();
?>

<?php
if(!isset($_SESSION["id"]))
  {
    echo '<script type="text/javascript" language="Javascript">  alert("Bitte loge dich zuerst ein!") </script> <meta http-equiv="refresh" content="0; URL=index.html">'; 
  }
  else
  {
    $id = ($_SESSION["id"]);
    $verbindung = mysql_connect("localhost", "planung" , "*************")
    or die("Verbindung zur Datenbank konnte nicht hergestellt werden");
    mysql_select_db("planung") or die ("Datenbank konnte nicht ausgewählt werden");
   
    $name = ($_POST["name"]);
    $vorname = ($_POST["vorname"]);
    $passwort = md5($_POST["passwort"]);
    $geburtsdatum = ($_POST["geburtsdatum"]);
    $strasse = ($_POST["strasse"]);
    $plz = ($_POST["plz"]);
    $email = ($_POST["email"]);
    $telefon = ($_POST["telefon"]);
    $admin = ($_POST["admin"]);
    $ahv = ($_POST["ahv"]);
    $lohn = ($_POST["lohn"]);
    $gruppe = ($_POST["gruppe"]);
   
    $abfrage = "SELECT * FROM mitarbeiter WHERE id LIKE '$id'";
    $ergebnis = mysql_query($abfrage);
    while($row = mysql_fetch_object($ergebnis))
        {
            if($row->admin == 5)
            {   
                if($_POST["passwort"] == $_POST["passwort2"])
                {
                    $eintrag = "INSERT INTO mitarbeiter (name, vorname, passwort, geburtsdatum, strasse, plz, e-mail, telefon, admin, ahv, lohn, gruppe) VALUES ('$name', '$vorname', '$passwort', '$geburtsdatum', '$strasse', '$plz', '$email', '$telefon', '$admin', '$ahv', '$lohn', '$gruppe')";
                    mysql_query($eintrag);
                    echo '<script type="text/javascript" language="Javascript">  alert("Benutzer wurde erfolgreich eingetragen!") </script> <meta http-equiv="refresh" content="0; URL=useradd.php">';
                }
                else
                {
                    echo '<script type="text/javascript" language="Javascript">  alert("Passwörter stimmen nicht überein!") </script> <meta http-equiv="refresh" content="0; URL=useradd.php">';
                }
            }
            else
            {
                echo '<script type="text/javascript" language="Javascript">  alert("Du bist kein Administrator!") </script> <meta http-equiv="refresh" content="0; URL=profil.php">';
            }
        }
  }
?>
 
Schön, und???

Meiner erwähnten Punkte hast du noch nicht erledigt.

Richtig debuggen

1. Man bemerkt, dass ein Skript nicht das tut, was es soll.
2. Man schreibt an den Anfang des Scriptes die Zeile: error_reporting(-1);
3. Man verwendet ini_set('display_errors', true); damit die Fehler auch angezeigt werden.
4. Man versucht, die Stelle die daran Schuld sein kann, schonmal einzugrenzen. Falls dies nicht geht, wird zunächst das komplette Skript als fehlerhaft angesehen.
5. An markanten Stellen im Skript lässt man sich wichtige Variableninhalte ausgeben und ggf. auch in bedingten Anweisungen eine kurze Ausgabe machen, um zu überprüfen, welche Bedingung ausgeführt wurde. Wichtig bei MySQL Fehlern (...not a valid MySQL result resource...): mysqli_error() verwenden oder Abfrage ausgeben und zb mit phpmyadmin testen.
6. Schritt 5 wird so lange wiederholt, bis Unstimmigkeiten im Skript auffallen
7. Damit hat man das Problem (Unstimmigkeit) gefunden und kann versuchen diese zu beheben. Hierzu dienen dann die PHP-Dokumentation und andere Quellen als Ratgeber.
8. Lässt sich das konkrete Problem trotzdem nicht beheben, kann man in Foren um Rat fragen.
9. Das Programm läuft und man kann die Debug-Ausgaben wieder entfernen.
 
Werbung:
Zurück
Oben