-2

このPHPコードをここで入手しました...

$totalBalance = 0;
    foreach($resultArray as $row) {
        foreach($row as $key =>$field) {
            echo $field['remaining'] . "<br>";
        }
    }

$ resultArrayは、SQLクエリから配列に返されるものです。

バランス列の最初のいくつかのレコードは..

389.96 6433.66 52.52 107.25

ただし、このphpコードを実行すると、

1 5 1 3

なぜこれを行うのですか、どうすれば修正できますか?

これが役立つ場合のSQLクエリです

SELECT c.clientid, c.clientname, c.billingdate, 
case when (select ifnull(sum(total), 0) from invoice i
where i.client = c.clientid and i.isdeleted = 0) - (select ifnull(sum(p.amount), 0) from payment p inner join invoice i on p.invoice = i.invoiceid
where i.client = c.clientid and i.isdeleted = 0) < 0 then (select ii.total from invoice ii where ii.client = c.clientid and ii.isdeleted=0 order by ii.invoiceid desc limit 1)  else (select ifnull(sum(total), 0) from invoice i
where i.client = c.clientid and i.isdeleted = 0) - (select ifnull(sum(p.amount), 0) from payment p inner join invoice i on p.invoice = i.invoiceid
where i.client = c.clientid and i.isdeleted = 0) end as remaining,
case c.isactive+0
        when '1' then 'Stop'
        else 'Start' 
        end as Active
FROM client c 
ORDER BY clientname

$ resultArrayのprint_rを実行して、これを取得しました...

Array ( [0] => Array ( [clientid] => 1 [clientname] => client A [billingdate] => 14 [remaining] => 389.96 [active] => Stop ) [1] => Array ( [clientid] => 178 [clientname] => client B [billingdate] => 23 [remaining] => 6433.66 [active] => Stop ) [2] => Array ( [clientid] => 3 [clientname] => client C [billingdate] => 19 [remaining] => 52.52 [active] => Stop ) [3] => Array ( [clientid] => 105 [clientname] => client D [billingdate] => 23 [remaining] => 107.25 [active] => Start )
4

3 に答える 3

1

あなたは1つの foreach を多くの人にやっています:

$totalBalance = 0;

foreach($resultArray as $row) {
  echo $row['remaining'] . "<br>";        
}

また、totalbalance を計算する場合は、次のようにします。

$totalBalance = 0;

foreach($resultArray as $row) {
  echo $row['remaining'] . "<br>";        
  $totalBalance += $row['remaining'] ; 
}

echo $totalBalance . "<br>";        
于 2012-09-06T19:59:56.157 に答える
0
<?php
$results = array( array('balance'=>123.45), array('balance'=>32.12));

$total = 0;

foreach( $results as $row )
{
    $total+=$row['balance'];
}

echo $total;
?>

出力:

155.57

于 2012-09-06T19:59:01.540 に答える
0

print_r から次のようにすべきではありません:

$totalBalance = 0;
    foreach($resultArray as $row) {
        foreach($row as $key =>$field) {
            echo $field['remaining'] . "<br>";
        }
    }

それ以外の :

$totalBalance = 0;
    foreach($resultArray as $row) {
        foreach($row as $key =>$field) {
            echo $field['balance'] . "<br>";
        }
    }
于 2012-09-06T20:06:59.747 に答える