PHP只返回第一个MySQL结果

时间:2012-08-02 20:29:03

标签: php mysql loops repeat

我有一个循环,应该显示所有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>";

}

非常感谢你!

4 个答案:

答案 0 :(得分:3)

那是因为你只获取了第一行(当你$res = mysql_fetch_assoc($result);时)。您尝试做的事实际上是不必要的:mysql_fetch_assoc()每次运行时都会自动将数据指针向前移动。你可以做什么(实际上是常见的做法)是:

//...
while ($res = mysql_fetch_assoc($result)) {
    echo "<a href='#'>{$res['dealer']}</a><br />";
}
//...

另外,mysql_*函数很快就会被弃用。您可以使用mysqliPDO代替;如果你是一个懒惰的流浪汉,有很多代码要切换(比如我),你可以使用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']; }