我有一个循环,应该显示所有MySQL结果的摘要。它通过确定可能的结果如何然后循环多次来实现这一点。因此,如果有43个结果与我的查询匹配,而不是显示所有43个结果,则它仅显示第一个结果43次。请帮忙!这是我的代码:
if (empty($res)) {
echo 'No results found';
} else if($num>1){
echo "<b>".$num_rows."<b> results found...<br>";
while ($res = mysql_fetch_assoc($result)) {
echo "<a href='#'>{$res['dealer']}</a><br>";
}
} else {
echo "<table border=\"0\"><tr><td colspan=\"2\"><span class=\"dealer\">" . $res['dealer'] . "</span></td></tr><tr><td><span class=\"label\">Pin: </span><span class=\"inf\">" . $res['pin'] . "</span></td><td><span class=\"label\">OB CODE: </span><span class=\"ob\">" . $res['ob'] . "</span></td></tr><tr><td><span class=\"label\">Program Director:</span></td><td><span class=\"inf\">" . $res['contact'] . "</span></td></tr><tr><td valign=\"top\"><span class=\"label\">Address:</span></td><td><span class=\"inf\">" . $res['address'] . "<br>" . $res['city'] . ", " . $res['state'] . "<br>" . $res['zip'] . "</span></td></tr><tr><td><span class=\"label\">Dealer Phone:</span></td><td><span class=\"inf\">" . $res['phone'] . "</span></td></tr><tr><td><span class=\"label\">Codes Valid on:</span></td><td><span class=\"inf\">" . $res['website'] . "</span></td></tr></table>";
}
非常感谢你!
答案 0 :(得分:3)
那是因为你只获取了第一行(当你$res = mysql_fetch_assoc($result);
时)。您尝试做的事实际上是不必要的:mysql_fetch_assoc()
每次运行时都会自动将数据指针向前移动。你可以做什么(实际上是常见的做法)是:
//...
while ($res = mysql_fetch_assoc($result)) {
echo "<a href='#'>{$res['dealer']}</a><br />";
}
//...
另外,mysql_*
函数很快就会被弃用。您可以使用mysqli
或PDO
代替;如果你是一个懒惰的流浪汉,有很多代码要切换(比如我),你可以使用mysqli
程序功能 - 它们几乎与原来的mysql_*
功能相同。
答案 1 :(得分:1)
你应该使用
$res = mysql_fetch_assoc($result);
每次要检索新行
答案 2 :(得分:1)
你必须在你的循环中
$res = mysql_fetch_assoc($result);
......因为这只会拉出第一个结果。这是正确的方法:
while($res = mysql_fetch_assoc($result)){
echo "<a href='#'>".$res['dealer']."</a><br>";
i++;
}
干杯
答案 3 :(得分:0)
使用:
while($res = mysql_fetch_assoc($result)) {
echo $res['dealer'];
}