Warum zeigt diese Abfrage nur ein Ergebnis?

Die folgende Abfrage wird als Suchskript verwendet. Aus irgendeinem Grund werden nicht alle Ergebnisse zurückgegeben, wenn eine der beiden Bedingungen erfüllt ist. Was mache ich falsch?

$sql = "SELECT name, id_code from codes WHERE name LIKE '%$q%' OR id_code 
LIKE '%$q%'";

$result = mysql_query($sql);

$query = mysql_query($sql) or die ("Error: ".mysql_error());

$num_rows1 = mysql_num_rows($result);

if ($result == "")
{
echo "";
}
echo "";


$rows = mysql_num_rows($result);

if($rows == 0)
{
print("<div id=norequests>No results for <strong>$q</strong></div>");

}
elseif($rows > 0)
{
while($row = mysql_fetch_array($query))
{

$name = htmlspecialchars($row['name']);
$code = htmlspecialchars($row['id_code']);

}

print("$code: $name<br /> <br />");
}

}


else{
    echo '<div id="error">No results for $q.</div>';
}

Antworten auf die Frage(3)

Ihre Antwort auf die Frage