[問題] FirstOrDefault vs Get all疑問

作者: windofsmile (微笑之風)   2018-10-17 11:54:49
各位版上的前輩們好
遇到一個瓶頸想請教一下各位大大
大致上的情況是
我有個Service已經成功取出我要的資料 但在篩選的時候出了問題
註解:A Table == 總表 == Taiwan
B Table == 關聯資料表 == Taiwan下的 Taipei
section == Taipei 的區域欄位 == 在Code中是public Enum
我的目標:
1.新店區所有記錄 費用加總 大安區所有記錄 費用加總
2.台北區所有費用加總
我的Code大概長這樣:
取出資料後
foreach (var m in viewModel.Taiwan)
{
if(m.Taipei !=null) //Taipei是關聯的資料表
{
if(m.Taipei.FirstOrDefault().section.Tostring().Equals("HsinTien"))
//因為是Enum所以需要Tostring()
{
Money1 = 0 ;
Money1 += Convert.ToInt32(m.section.FirstOrDefault().Price)
//將Taipei中,記錄為"新店區"的費用都加進來
}
if(m.Taipei.FirstOrDefault().section.Tostring().Equals("TaAn"))
{
Money2 = 0 ;
Money2 += Convert.ToInt32(m.section.FirstOrDefault().Price)
}
}
//最後再去做各區費用加總
//在SQL的Table中 HsinTien或TaAn或其他區域的記錄會有不止一筆 即重複值
}
目前遇到的情況是
在取得子資料表(Taipei)時,監看式內呈現的資料都正確
像是新店區共3筆 大安區共5筆之類
但在進一步篩選時就爆炸了 目前下中斷點 發現問題出在我使用了
FirstOrDefault這個方法,所以導致他只會取得第一筆資料
後面第二筆新店 第二筆大安等重複的資料以及判斷式內 該區域的Price就不會累加進來
有查了許多方法,但不知道除了FirstOrDefault LastOrDefault SingleOrDefault等
取得單項的方法之外 有沒有哪個方法 或是關鍵字可以讓我取到所有資料的呢?
查過elementAt 但這個是指定第幾個元素
另外 也有嘗試過
直接if(m.Taipei.section.Equals("區域名"))
但m.Taipei.section會顯示ICollection<Taipei>未包含section的定義
沒辦法直接取得section欄位
不知道版上的大大們有沒有什麼推薦的關鍵字 或是方法
可以讓小弟有個方向再找看看解法的呢?
先謝過願意回覆的大大們<_O_>
作者: YahooTaiwan (超可愛南西我老婆)   2018-10-17 12:46:00
foreach?
作者: jun112561 (孤之界)   2018-10-17 13:39:00
你用的三個方法都是針對抓取單一資料的,我個人的話會選擇用Where(System.Linq)裡的擴充函式,然後用Foreach加總
作者: petercoin (彼得幣)   2018-10-17 13:57:00
同上 但是我會直接轉成List然後呼叫用.Sum()直接加總
作者: ian90911 (xopowo)   2018-10-17 14:01:00
where過濾只有新店大安 然後groupby select sum
作者: Litfal (Litfal)   2018-10-17 15:43:00
用groupby比較正確為什麼你不從 Taipei 甚至 section 的表來撈就好...
作者: CloudyWing (孤單ㄉ翼)   2018-10-17 22:21:00
如果要處理的欄位不多的話https://dotnetfiddle.net/hkwLiv
作者: Litfal (Litfal)   2018-10-17 22:24:00
資料庫設計,應該是section *-0..1 Taipei *-1 Taiwan 吧
作者: CloudyWing (孤單ㄉ翼)   2018-10-17 22:39:00
或著是這樣https://dotnetfiddle.net/8sbYlC話說我總覺得你表設計怪怪的,應該是Litfal大那樣才對

Links booklink

Contact Us: admin [ a t ] ucptt.com