這段迴圈要怎麼糾正?
$sa='select * from pql_spices_class order by id asc';
$ra=mysql_query($sa);
$i=1;
while($rsa=mysql_fetch_array($ra,MYSQL_ASSOC))
{
//echo $rsa['classname'].",".$rsa['id']."
";
$cid = $rsa['id'];
$resf=mysql_query('SELECT * FROM `pql_spices` where classid='.$cid.' ORDER BY id DESC');
while($rsf=mysql_fetch_array($resf))
{
$Prices+=$rsf['Price'];
}
echo $i."、".$rsa['classname'].":".$Prices."元,";
$i++;
}
一個分類資料表pql_spices_class:有 分類一、分類二、分類三、……每個分類有對應的ID
一個列表資料表pql_spices:有商品名稱、價格、分類ID、分類名稱
要把pql_spices表裡的價格按分類分別統計價格總價,但我這段代碼的結果是:分類一統計對了,到了分類二確是分類一的總和加上分類二的總和,到了分類三確是分類二+加上分類三的總和,以此類推,每一次新分類的統計都會自動加上 上一次分類的統計總和,這就不對了。
請問代碼要怎麼寫,才能準確得到各自分類的統計。不知道這樣提問大家能不能明白我要問的意思。
------解決思路----------------------
你的 $Prices 總是累加沒有清0,自然就是現在的結果
再說一個分組求和的查詢指令就可完成的事情,為何要用迴圈累加完成?
------解決思路----------------------
$sa='select * from pql_spices_class order by id asc';
$ra=mysql_query($sa);
$i=1;
while($rsa=mysql_fetch_array($ra,MYSQL_ASSOC))
{
[color="red"]$Prices=0;//這裡清零[/color]
//echo $rsa['classname'].",".$rsa['id']."
";
$cid = $rsa['id'];
$resf=mysql_query('SELECT * FROM `pql_spices` where classid='.$cid.' ORDER BY id DESC');
while($rsf=mysql_fetch_array($resf))
{
$Prices+=$rsf['Price'];
}
echo $i."、".$rsa['classname'].":".$Prices."元,";
$i++;
}