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

Problem mit INSERT

Maximilian

Mitglied
Hallo,

ich bin am verzweifeln! Ich versuche, Datensätze in eine Datenbank zu schreiben, jedoch nur, wenn in den Input bzw. Select - Feldern etwas steht. An sich nicht schwer; meine Idee: Mit isset und einer if Abfrage prüfen, ob etwas drinnen steht und anschließen die Daten in die DB schreiben. Mein Ansatz:

PHP:
    if(isset($_POST['sp1_name'], $_POST['sp1_holz'], $_POST['sp1_raeumen'], $_POST['sp1_fehler'], $_POST['sp1_satzpunkte'], $_POST['sp1_mannschaftspunkte'])) {
    
    $spieltag = $_POST['spieltag_select'];
       
    $sp1_name = $_POST['sp1_name'];
    $sp1_holz = $_POST['sp1_holz'];
    $sp1_raeumen = $_POST['sp1_raeumen'];
    $sp1_fehler = $_POST['sp1_fehler'];
    $sp1_satzpunkte = $_POST['sp1_satzpunkte'];
    $sp1_mannschaftspunkte = $_POST['sp1_mannschaftspunkte'];
    
    
     $insert_sp1 = "INSERT INTO saison1415_herren1 VALUES ('".$spieltag."', '".$sp1_name."', '".$sp1_holz."', '".$sp1_raeumen."', '".$sp1_fehler."', '".$sp1_satzpunkte."', '".$sp1_mannschaftspunkte."')";
            $eintragen1 = mysql_query($insert_sp1) OR die (mysql_error());
    }
    
    else {
    
    echo "Spieler 1 nicht ausgefüllt.";
    }

Es funktioniert aber nicht! Es wird immer eine leere Zeile und der Spieltag in meine Tabelle in der DB eingetragen. Hab schon sämtliche Ansätze, das Problem zu lösen durchprobiert aber langsam gehen mir die Ideen aus...

Schon jetzt vielen Dank für eure Hilfe!

LG
 
Werbung:
Mit isset prüfst du nicht, ob ein Wert in der Variable steckt, sondern nur, ob diese Variable existiert. Du suchst empty

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