0

我是 PHP 的新手,所以这个问题可能很愚蠢。搜索了几个小时后我找不到答案。

我已经使用 foreach 循环进行了查询,但它没有在我创建的表中正确显示。来自 foreach 的部分全部显示在最后一个国家/地区旁边的字段中。

我试图把它放在所有其他地方,但结果保持不变,它没有出现在正确的列中。

$query = "SELECT COUNT(landofbirth) as c, landofbirth FROM dog WHERE landofbirth IS NOT NULL GROUP BY landofbirth ORDER BY c desc LIMIT 1000"; 
$result = mysql_query($query) ;
$values = array();
$pct = array();
$total = 0;

while ($line = mysql_fetch_array($result)) {
    echo "<tr><td>";
    $values[$line[1]] = $line[0];
    $total += $line[0];
    echo "$line[1]</td><td> ";

    echo "$line[0] </td><td>"; }

    foreach($values as $key => $value) {
    $pct[$key] = $value/$total ; 
    $count2 = $pct[$key] * 100;
    $count = number_format($count2, 2);
    echo "$count %"; }
    echo "</td></tr>";
4

1 回答 1

4

您的代码有点乱码,可能是因为它移动了太多次。

我总是发现将显示项目一个接一个地分开是很有帮助的,甚至将它们放在单独的行上,并远离“计算”代码,以便在编辑代码时获得更好的视觉效果。

我不确定这是否是您要查找的内容,但我认为此显示将很接近(和/或易于修改):

while ($line = mysql_fetch_array($result)) {
    $values[$line[1]] = $line[0];
    $total += $line[0];
}

foreach($values as $key => $value) {
    $pct[$key] = $value/$total ; 
    $count2 = $pct[$key] * 100;
    $count = number_format($count2, 2);

    echo '<tr>';
        echo '<td>' . $key . '</td>';
        echo '<td>' . $value . '</td>';
        echo '<td>' . $count . '%</td>';
    echo '</tr>';
}

旁注(不具体回答)
建议您不要使用mysqlPHP 中已弃用的扩展进行开发。相反,您应该使用替代和维护mysqliPDO扩展。两者使用起来都更加安全,提供了有益的功能,例如准备好的语句!

于 2013-06-04T04:09:00.713 回答