Eingabe in einer Datenbank

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

  • Eingabe in einer Datenbank

    Hallo,
    ich erstelle gerade eine Seite in Verbindung sql......

    für die Eingabe in einer DB musste ich mich schlau machen und habe auch einen Skript gefunden . Die Tabelle in SQL wurde passend schon erstellt. Vorname, Nachname, Anmerkung und zuletzt Geändert. Spalten sind da und eine Entsprechende Ausgabe funktionert. Nur die Eingabe nicht. Warum ? Fehlen mir hier Werte??
    PHP-Code:
    <?php
      
    require ('.../conf/db.php');

    $spalten = [
      
    'vorname' => 'Vorname',
      
    'nachname' => 'Nachname',
      
    'anmerkung' => 'Anmerkung',

    ];


    <?php
    if(isset($_POST['neu'])) {
      
    $schluessel = [];
      
    $werte = [];
      
    $platzhalter = [];

      foreach (
    $spalten as $spalte => $name) {
          
    $schluessel[] = '`'.$spalte.'`';
          
    // Zu lange Eingaben kürzen
          
    if(mb_strlen($_POST[$spalte]) > 256) {
            
    $_POST[$spalte] = mb_substr($_POST[$spalte], 0256);
          }
          
    $werte[] = $_POST[$spalte]??'';
          
    $platzhalter[] = '?';
      }
      
    $werte[] = time();
      
    $query 'INSERT INTO `adressen` ('.implode(', '$schluessel).', `zuletzt_geaendert`)
                VALUES ('
    .implode(', '$platzhalter).')';
      
    $stmt $dbh->prepare($query);
      
    $stmt->execute($werte);
      
    header('Location: .');
      die();
    }
    ?>
    <form method="post">
      <fieldset>
        <legend>Neuer Eintrag</legend>
    <?php
    foreach($spalten as $schluessel => $name) {
      echo 
    '<label><input type="text" name="',
        
    htmlspecialchars($schluesselENT_QUOTES ENT_HTML5), '" maxlength="256"> ',
        
    htmlspecialchars($name),
        
    '</label><br>';
    }
    ?>
        <button name="neu" value="1">Eintragen</button>
      </fieldset>
    </form>​

  • #2
    Immer wieder wichtig:

    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.

    Die Ausgaben per echo bzw. var_dump kann man sich ersparen, in dem man einen Debugger benutzt.

    Kommentar

    Lädt...
    X