推 YahooTaiwan: foreach? 10/17 12:46
推 jun112561: 你用的三個方法都是針對抓取單一資料的,我個人的話會 10/17 13:39
→ jun112561: 選擇用Where(System.Linq)裡的擴充函式,然後用Foreac 10/17 13:39
→ jun112561: h加總 10/17 13:39
→ petercoin: 同上 但是我會直接轉成List然後呼叫用.Sum()直接加總 10/17 13:57
推 ian90911: where過濾只有新店大安 然後groupby select sum 10/17 14:01
感謝各位大大QQ 我剛才發現一個很根本性的錯誤
在於 Taipei這個Table在Code裡面 (由第一個foreach抓出來後)是陣列
如果我沒有使用foreach去讀取這個陣列的話 就只能用FirstOrDefault等方法
才能去讀取到Taipei的section
Where的方法跟轉成List的方法 我會再找時間試試看的 多學一招是一招QQ
我目前的Code大概長這樣
foreach (var a in viewModel.Taiwan)
{
Money1 = 0; Money2 = 0 //進迴圈時先歸零
if (a.Taipei != null ) //taipei有東西才進去
{
try
{
foreach (var b in a.Taipei) //很重要的foreach讀取BTable(陣列)
{
if (b.section.ToString().Equals("新店區"))
{
Money1 += Convert.ToInt32(b.Price);
}
if (b.section.ToString().Equals("大安區"))
{
Money2 += Convert.ToInt32(b.Price);
}
}
費用計算...
}
catch
{
略..
}
}
這樣的結果可以讓重複的筆數都成功加總,一開始的歸零也不會讓前面的金額影響
到後面的金額,十分感謝各位前輩的幫忙QQ
希望之後我也有機會可以幫助別人<_O_>
※ 編輯: windofsmile (211.20.227.179), 10/17/2018 14:47:23
推 Litfal: 用groupby比較正確 10/17 15:43
大大是指加總的時候嗎?
※ 編輯: windofsmile (211.20.227.179), 10/17/2018 15:46:39
※ 編輯: windofsmile (211.20.227.179), 10/17/2018 15:47:08
→ Litfal: 為什麼你不從 Taipei 甚至 section 的表來撈就好... 10/17 15:56
因為這是畫面上其中一個查詢結果的某個欄位
還是有用到Taiwan Table的其他欄位資料@@
※ 編輯: windofsmile (211.20.227.179), 10/17/2018 16:12:24
※ 編輯: windofsmile (211.20.227.179), 10/17/2018 16:18:08
推 CloudyWing: 如果要處理的欄位不多的話 10/17 22:21
→ Litfal: 資料庫設計,應該是section *-0..1 Taipei *-1 Taiwan 吧 10/17 22:24
推 CloudyWing: 話說我總覺得你表設計怪怪的,應該是Litfal大那樣才對 10/17 22:43