3

我有以下 php 代码:

echo "<div style='float:left;'>";
echo "<table>";
echo "<tr>";
echo "<th></th>";
echo "<th colspan='4'>Laks beholdt</th>";
echo "</tr>";
echo "<tr>";
echo "<th>Uke</th>";
echo "<th>&lt;3 kg</th>";
echo "<th>3-7 kg</th>";
echo "<th>&gt;7 kg</th>";
echo "<th>Totalt</th>";
echo "</tr>";

while ($row = mysql_fetch_array($result, MYSQL_ASSOC) or die(mysql_error()))
{
   echo "<tr>";
   echo "<td>" . $row['Uke'] . "</td>";
   echo "<td style='text-align:right; padding-right:10px;'>" . number_format($row['SumSmall'], 1,
      ",", " ") . " kg</td>";
   echo "<td style='text-align:right; padding-right:10px;'>" . number_format($row['SumMedium'], 1,
      ",", " ") . " kg</td>";
   echo "<td style='text-align:right; padding-right:10px;'>" . number_format($row['SumLarge'], 1,
      ",", " ") . " kg</td>";
   echo "<td style='text-align:right; padding-right:10px;'>" . number_format($row['SumVekt'], 1, ",",
      " ") . " kg</td>";
   echo "</tr>";
}

echo "</table>";
echo "</div>";

我从 while 循环中获得了预期的输出,但我的表和 div 的结束标签 - 或任何其他输出 - 没有显示。我没有收到任何错误消息,也没有在我的 html 中看到任何错误。我尝试通过数字而不是关联来引用数组,但我得到了相同的结果。

我已经写了一百个类似的循环没有错误,但我在这里没有想法:/

4

4 回答 4

6

or die()语句导致它停止执行。什么时候$row = mysql_fetch_array($result, MYSQL_ASSOC)应该停止循环,它会die()改为。由于没有错误,因此没有打印任何内容mysql_error()

echo "Before loop\n";

$x = 1;
while($foo = bar($x) or die('Died')) {
    echo $x++, "\n";
}

echo "After loop\n";

function bar($x) {
    if($x < 5) {
        return $x;
    }
    return false;
}

//outputs:
//Before loop
//1
//2
//3
//4
//Died

键盘版本

于 2012-04-19T17:32:57.357 回答
2

不要die()在循环中使用

while ($row = mysql_fetch_array($result, MYSQL_ASSOC))
{
   echo "<tr>";
   echo "<td>" . $row['Uke'] . "</td>";
   echo "<td style='text-align:right; padding-right:10px;'>" . number_format($row['SumSmall'], 1,
      ",", " ") . " kg</td>";
   echo "<td style='text-align:right; padding-right:10px;'>" . number_format($row['SumMedium'], 1,
      ",", " ") . " kg</td>";
   echo "<td style='text-align:right; padding-right:10px;'>" . number_format($row['SumLarge'], 1,
      ",", " ") . " kg</td>";
   echo "<td style='text-align:right; padding-right:10px;'>" . number_format($row['SumVekt'], 1, ",",
      " ") . " kg</td>";
   echo "</tr>";
}
于 2012-04-19T17:32:41.343 回答
1

您的 while 条件有缺陷,因为当从结果集中获取所有行时mysql_fetch_array()返回,因此 while 条件变为执行并终止脚本。falsefalse or die(mysql_error())die()

您不应该使用或喜欢那样,也不应该像那样将错误打印到屏幕上。

您正在执行的错误报告类型应取决于您是在生产还是开发,但无论如何都应执行错误检查。

我建议您强烈考虑类似PDO例外mysqliPHP framework完全例外的事情。使用mysql_*() API.

于 2012-04-19T17:33:50.113 回答
1

这是生死攸关的陈述。如果您想让循环在错误上终止,请设置一个自定义错误处理函数,如果有错误,该函数会设置一个布尔值。然后你可以做类似的事情

while ($row = mysql_fetch_array($result, MYSQL_ASSOC) or !$error_hander)
于 2012-04-19T17:37:14.047 回答