0

我正在尝试从 row['scores'] 添加值。

例如,如果我有 6 行,每行的值为 1.. 我希望能够回显 -> 行的值 = 6。

+=对我不起作用:我仍然只得到值本身,例如 1,2,3,4,5,6,7 但我想要它的总和,比如说 1+2+3+4+5+6 +7=28。

谢谢

<?php include("connect.php"); ?>

<html>
    <head>
        <title>Score Predictions</title>
    </head>
    <body>

        <div id = "id">

<?php
    $query = "SELECT * FROM test";
    $result = mysql_query($query);

    while ($row = mysql_fetch_array($result)) {
        $id = $row['id'];
        $home = $row['home'];
        $away = $row['away'];
    }
?>

<?php
    if (isset($_POST['submit'])) {
        $x = $_POST["test"];
        mysql_query("INSERT INTO test (home, away, score) VALUES ('$home', '$away', '$x')");
    }
?>

<?php echo $home," - ",$away; ?>

    <form method = 'post' action = 'http://albsocial.us/test/index.php'>
        <select name = 'test'> 
            <option value = "" selected = 'selected'></option>
            <option VALUE = '1'>1</option>
            <option VALUE = 'X'>X</option>
            <option VALUE = '2'>2</option>   
        </select>
        <INPUT TYPE = 'submit' name = 'submit' />
    </form>

<?php
    $query = "SELECT * FROM test";
    $result = mysql_query($query);

    while($row = mysql_fetch_array($result)) {
        $id = $row['id'];
        $score = $row['score'];
        if ($score == "1") {
            echo $sum += $score - 1;
        }
    }
?>

        </div>
    </body>
</html>
4

3 回答 3

2
$sum=0; 
         while($row=mysql_fetch_array($result)){

                 $id = $row['id'];
                 $score = $row['score'];

                     if ($score == "1"){

                         $sum = $sum+$score;

                     }

         }
echo $sum;

尝试这个。它总结了 al $score 值。

于 2013-06-13T04:13:18.483 回答
2

您必须删除if条件并将数据库值添加到$sum变量

$sum = 0;
while($row=mysql_fetch_array($result)){

   $id = $row['id'];
   $score = $row['score'];
   $sum += (int)$score;
}   
echo $sum;
于 2013-06-13T04:13:59.840 回答
0

这里有几个问题,因为其他答案大多可以解决,但要明确:

  • if $score == 1似乎与你的目的无关。你的意思是if $id == 1,还是你只是想忽略零?(anything + zero 无论如何都保持不变,所以你不需要)
  • 似乎没有理由在$sum += $score-1两者中减去一个
  • 您需要先完成加起来,然后再调用echo一次。目前,echo每个数据库行都有一个,这就是为什么您会看到多个数字输出。
  • 如果您只显示总和,则根本不需要循环执行此操作,只需让数据库为您加起来,例如SELECT SUM(score) AS total_score FROM testSELECT id, SUM(score) AS total_score FROM test GROUP BY id
于 2013-06-13T04:35:56.900 回答