Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Durchsuchen Sie die MySQL-Tabelle mit Formular und zeigen Sie die Ergebnisse an

Nein, Sie haben eine vorbereitete Anweisung erstellt, dann haben Sie die normale Abfrage mit den Platzhaltern verwendet, deshalb funktioniert sie nicht. Führen Sie die vorbereitete Anweisung aus und rufen Sie dann das Ergebnis dieser vorbereiteten Anweisung ab.

$query = "SELECT * FROM photos WHERE cata=? OR catb=? OR catc=?";
$conn = $db->prepare($query);
$conn->bind_param("sss", $cata, $catb, $catc);
$conn->execute();
$conn->bind_result($cata, $catb, $catc);
?>
<table border="1">
<tr>
    <th>cata</th>
    <th>catb</th>
    <th>catc</th>
</tr>
<?php
while ($conn->fetch()) {

    echo '<tr>';
    echo '<td>' . $cata . '</td>';
    echo '<td>' . $catb . '</td>';
    echo '<td>' . $catc . '</td>';
    echo '</tr>';
}

Oder wenn Sie den mysqlnd haben (Mysql nativer Treiber / oder Sie haben diese undefinierte Funktion nicht), Sie können auch get_result() verwenden :

$query = "SELECT * FROM photos WHERE cata=? OR catb=? OR catc=?";
$conn = $db->prepare($query);
$conn->bind_param("sss", $cata, $catb, $catc);
$conn->execute();
$results = $conn->get_result(); // i like this better
?>
<table border="1">
<tr>
    <th>cata</th>
    <th>catb</th>
    <th>catc</th>
</tr>
<?php
while ($row = $results->fetch_assoc()) {

    echo '<tr>';
    echo '<td>' . $row['cata'] . '</td>';
    echo '<td>' . $row['catb'] . '</td>';
    echo '<td>' . $row['catc'] . '</td>';
    echo '</tr>';
}

?>