找回密碼 或 安全提問
 註冊
|註冊|登錄

伊莉討論區

搜索
搞笑、娛樂、精彩的影片讓你看你準備好成為出色的版主了嗎?安全提問(回答) 和 永久尊貴會員 事宜
波多野結進擊的巨世紀帝國mg 無碼vrrpggd
蝶が舞う1114カスタムrbk 087おとめviolatedfsdss

休閒聊天興趣交流學術文化旅遊交流飲食交流家庭事務PC GAMETV GAME
熱門線上其他線上感情感性寵物交流家族門派動漫交流貼圖分享BL/GL
音樂世界影視娛樂女性頻道潮流資訊BT下載區GB下載區下載分享短片
電腦資訊數碼產品手機交流交易廣場網站事務長篇小說體育運動時事經濟
上班一族博彩娛樂

(4月新番)[繁]終末的

文化大革命 紀實錄像

[繁]轉生貴族憑鑑定技

[繁]關於我轉生變成史

[繁]月光下的異世界之

(4月新番)[繁]THE NEW
C & C++ 語言C# 語言Visual Basic 語言PHP 語言JAVA 語言
查看: 4902|回復: 7
打印上一主題下一主題

[問題]讀出資料庫的某欄位進行加總[複製鏈接]

Rank: 1

帖子
110
積分
140 點
潛水值
22870 米
跳轉到指定樓層
樓主
發表於 2016-8-6 03:42 PM|只看該作者|倒序瀏覽
如果你忘記伊莉的密碼,請在登入時按右邊出現的 '找回密碼'。輸入相關資料後送出,系統就會把密碼寄到你的E-Mail。
  1. <?php
  2. $odate=$_GET['odate'];
  3. $link = @mysql_connect("localhost","root","123456") or die("無法聯上資料庫".mysql_error());
  4. $sql="select opp from oo where odate = '$odate' ";
  5. $result = mysql_db_query("dragon",$sql,$link);
  6. while(list($opp)=mysql_fetch_array($result))
  7. {
  8. echo $opp;


  9. }

  10. foreach ($opp as $value){
  11.         $total = $total + $value;
  12.         echo $total;
  13.        
  14.         }


  15. ?>
複製代碼
我想對資料庫欄位中的 opp 所有數量進行加總
本來想說從資料庫讀到的陣列直接用array_sum
不行~
又試了foreach
也不行~所以來此請教了...
瀏覽完整內容,請先 註冊登入會員

點評

hsw1976 很好奇你為什麼一直在犯同樣的毛病:能在資料庫端處理掉的事,偏偏要拿來程式端處理。  發表於 2016-8-8 03:15 AM
分享分享0收藏收藏0支持支持0

使用道具檢舉

Rank: 3Rank: 3Rank: 3

帖子
663
積分
1128 點
潛水值
20810 米
頭香
發表於 2016-8-8 12:16 PM|只看該作者
如果發覺自己無法使用一些功能或出現問題,請按重新整理一次,並待所有網頁內容完全載入後5秒才進行操作。
從代碼上來看應該是新手吧

首先有一個很重要的觀念, 就是loop(無論是for, foreach, while, do)裡面的變數, 你必須在loop裡面處理掉, 你帶出來外面的話, 他只會存到最後一次的值.

在你的情況就是
  1. $total = 0; // 初始化是好習慣
  2. while(list($opp)=mysql_fetch_array($result))
  3. {
  4.     echo $opp;
  5.     $total = $total + $value;
  6.     echo $total;
  7. }
複製代碼
如果你要分開做也不是不行, 那你就得先把它弄成一個array
  1. $temp_array = [];
  2. while(list($opp)=mysql_fetch_array($result))
  3. {
  4.     echo $opp;
  5.     $temp_array[] = $opp; // 把數值加入array裡
  6. }

  7. // 然後做你要的東西
  8. foreach ($temp_array as $value) {
  9.   ???
  10. }
複製代碼
最後像版主所說, 有些東西是可以直接在SQL解決的, 例如你例子的sum
  1. select sum(opp) from oo where odate = '$odate'
複製代碼
或是
  1. select odate, sum(opp) from oo group by odate
複製代碼
...
瀏覽完整內容,請先 註冊登入會員

點評

hsw1976 都在這個板混多久了,還新手。  發表於 2016-8-9 03:24 PM
回覆中加入附件並不會使你增加積分,請使用主題方式發佈附件。

使用道具檢舉

Rank: 1

帖子
110
積分
140 點
潛水值
22870 米
3
發表於 2016-8-8 07:39 PM|只看該作者
如果你忘記伊莉的密碼,請在登入時按右邊出現的 '找回密碼'。輸入相關資料後送出,系統就會把密碼寄到你的E-Mail。
theloserbm 發表於 2016-8-8 12:16 PM
下載: 訪客無法瀏覽下載點,請先 註冊登入會員

從代碼上來看應該是新手吧

首先有一個很重要的觀念, 就是loop(無論是for, foreach, while, do)裡面的變數, ...

那那那....我從書上的確看到可以從資料庫去處理~用sum(opp)變數
...
瀏覽完整內容,請先 註冊登入會員
若瀏覽伊莉的時侯發生問題或不正常情況,請使用Internet Explorer(I.E)。

使用道具檢舉

Rank: 3Rank: 3Rank: 3

帖子
663
積分
1128 點
潛水值
20810 米
4
發表於 2016-8-8 10:13 PM|只看該作者
第一種的話比較直接
因為只返回一欄, 所以直接讀取就可以了
  1. select sum(opp) from oo where odate = '$odate'
  2. if (list($sum)=mysql_fetch_array($result))
  3. {
  4.     echo $sum;
  5. }
複製代碼
第二種其實也不難, 把返回的兩欄當作普通table就可以了
  1. select odate, sum(opp) from oo group by odate
  2. while(list($date, $total)=mysql_fetch_array($result))
  3. {
  4.     echo $date . '-' . $total . '<br>';
  5. }
複製代碼
...
瀏覽完整內容,請先 註冊登入會員
若對尊貴或贊助會員有任何疑問,歡迎向我們查詢。我們的即時通或MSN: admin@eyny.com

使用道具檢舉

Rank: 1

帖子
110
積分
140 點
潛水值
22870 米
5
發表於 2016-8-9 08:28 PM|只看該作者
若瀏覽伊莉的時侯發生問題或不正常情況,請使用Internet Explorer(I.E)。
theloserbm 發表於 2016-8-8 10:13 PM
下載: 訪客無法瀏覽下載點,請先 註冊登入會員

第一種的話比較直接
因為只返回一欄, 所以直接讀取就可以了第二種其實也不難, 把返回的兩欄當作普通table就 ...

太好了~it works!!!
...
瀏覽完整內容,請先 註冊登入會員





使用道具檢舉

Rank: 1

帖子
110
積分
140 點
潛水值
22870 米
6
發表於 2016-8-14 03:44 PM|只看該作者
成為伊莉的版主,你將獲得更高級和無限的權限。把你感興趣的版面一步步地發展和豐盛,那種滿足感等著你來嚐嚐喔。
goddamnx2 發表於 2016-8-9 08:28 PM
下載: 訪客無法瀏覽下載點,請先 註冊登入會員

太好了~it works!!!
thank you very much
  1. <?php


  2. echo oppcount("2016-08-18");

  3. $link = @mysql_connect("localhost","root","123456") or die("無法聯上資料庫".mysql_error());

  4. function oppcount($odate=""){
  5.   global $link;
  6.   $sql="select sum(opp) from oo where odate = '$odate' ";
  7.   $result=mysql_db_query("dragon",$sql,$link) or die("無法取日記資料!<br>".$sql);
  8.   $sum = mysql_fetch_array($result);
  9.   return $sum;

  10. }
  11. ?>
複製代碼
我嘗試把這段語法寫成函數,結果卻失敗了==//
大大please~又錯在哪了??...
瀏覽完整內容,請先 註冊登入會員

點評

theloserbm PHP 的函數好像必須有return type吧...  發表於 2016-8-15 10:52 AM
回覆中加入附件並不會使你增加積分,請使用主題方式發佈附件。

使用道具檢舉

Rank: 1

帖子
110
積分
140 點
潛水值
22870 米
7
發表於 2016-8-16 08:27 PM|只看該作者
若瀏覽伊莉的時侯發生問題或不正常情況,請使用Internet Explorer(I.E)。
haha~我知道問題在哪了~
$link要放到第一行
否則就會出錯誤
若新密碼無法使用,可能是數據未更新。請使用舊密碼看看。

使用道具檢舉

s947477 該用戶已被刪除
8
發表於 2016-9-18 02:39 AM|只看該作者
若新密碼無法使用,可能是數據未更新。請使用舊密碼看看。
goddamnx2 發表於 2016-8-16 08:27 PM
下載: 訪客無法瀏覽下載點,請先 註冊登入會員

haha~我知道問題在哪了~
$link要放到第一行
否則就會出錯誤

php  不夠嚴謹的地方 使用其他框架會強調個錯誤...
瀏覽完整內容,請先 註冊登入會員
回覆中加入附件並不會使你增加積分,請使用主題方式發佈附件。

使用道具檢舉

您需要登錄後才可以回帖 登錄 | 註冊

Powered by Discuz!

© Comsenz Inc.

重要聲明:本討論區是以即時上載留言的方式運作,對所有留言的真實性、完整性及立場等,不負任何法律責任。而一切留言之言論只代表留言者個人意見,並非本網站之立場,用戶不應信賴內容,並應自行判斷內容之真實性。於有關情形下,用戶應尋求專業意見(如涉及醫療、法律或投資等問題)。 由於本討論區受到「即時上載留言」運作方式所規限,故不能完全監察所有留言,若讀者發現有留言出現問題,請聯絡我們。有權刪除任何留言及拒絕任何人士上載留言,同時亦有不刪除留言的權利。切勿上傳和撰寫 侵犯版權(未經授權)、粗言穢語、誹謗、渲染色情暴力或人身攻擊的言論,敬請自律。本網站保留一切法律權利。
回頂部