這段迴圈要如何糾正

來源:互聯網
上載者:User
這段迴圈要怎麼糾正?
$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++;

}
  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.