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

Suchformular mit mehreren Inputfeldern

mazcapone

Neues Mitglied
Hallo liebe Leute, ich möchte ein Suchformular machen mit mehreren Inputfeldern (z.B. Kundenummer, Name und Datum) - dazu habe ich auch schon eine .html Datei (siehe unten) und dann sollen die begriffe (searchterms) nach denen gesucht werden soll - in die php Datei übetragen (dazu auch unten separat die php Datei) . Die Möglichkeit soll sein, dass man wenn man nach einem "Max" sucht - halt alle ausgegeben werden wo der Name = "Max" ist. gibt man noch einen Kundenummer ein, soll auch nur der Max aus der Datenbank herausgefiltert werden, mit der richtigen Nummer. Mit den beiden Dateien, bin ich nun soweit, dass mir zumindest des Text: "Das Ergebnis:" ausgegeben wird. Aber eben ohne Ergebnis.
Hier die html Datei:
Code:
<!DOCTYPE html>
<html lang="de">

    <head>
        <meta charset="utf-8">
        <link rel="stylesheet" href="stylesheet.css">
        <title>ReklaMation</title>
    </head>

<body>

<!-- Damit dass CSS greift main role eingefügt -->
<main role="main">

<form action="searchengine.php" method="post">

<table>
    <tr><td>Kundenummer</td>    <td><input name="kdnr" type="integer"></td>
    <tr><td>Name</td>            <td><input name="name" type="text"></td></tr>
    <tr><td>Datum</td>             <td><input name="datum" type="date"></td></td>
    </tr>
</table>   
<!-- Button zum suchen -->

<input name="searchterm" type="text">
<input name="submit" type="submit" value="FINDEN">
</form>


</main>
</body>
</html>

und hier die .php Datei:
Code:
<?php

// Verbindung zur Datenbank
  $mysqli = new mysqli( 'localhost', 'root', 'hollywood', 'forms1' );
 
  // Prüfen, ob die Verbindung hergestellt werden konnte
  if ( $mysqli->connect_error ) {
    die( 'Verbindungsfehler: ' . $mysqli->connect_errno . ': ' . $mysqli->connect_error );
  }
 
$begriff = mysqli_real_escape_string($mysqli, $_POST['searchterm']);
$while = ($row = $mysqli->query("SELECT *
                                FROM kundentest
                                WHERE
                                kdnr ='".$begriff."' OR
                                name = '".$begriff."' OR
                                datum = '".$begriff."' ")->fetch_assoc());
                                   
{
$ergebnis = $row["kdnr, name, datum"];
echo "Das Ergebnis: $ergebnis";

}
// Schließen der Verbindung zur Datenbank
  $mysqli->close();

?>

</main>
</body>
</html>

Was ist hier alles falsch ?
 
Werbung:
Wo kommt denn $_POST['searchterm'] her?

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