[問題] FirstOrDefault vs Get all疑問
各位版上的前輩們好
遇到一個瓶頸想請教一下各位大大
大致上的情況是
我有個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_>
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 211.20.227.179
※ 文章網址: https://www.ptt.cc/bbs/C_Sharp/M.1539748492.A.B52.html
推
10/17 12:46,
6年前
, 1F
10/17 12:46, 1F
推
10/17 13:39,
6年前
, 2F
10/17 13:39, 2F
→
10/17 13:39,
6年前
, 3F
10/17 13:39, 3F
→
10/17 13:39,
6年前
, 4F
10/17 13:39, 4F
→
10/17 13:57,
6年前
, 5F
10/17 13:57, 5F
推
10/17 14:01,
6年前
, 6F
10/17 14:01, 6F
感謝各位大大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
推
10/17 15:43,
6年前
, 7F
10/17 15:43, 7F
大大是指加總的時候嗎?
※ 編輯: windofsmile (211.20.227.179), 10/17/2018 15:46:39
※ 編輯: windofsmile (211.20.227.179), 10/17/2018 15:47:08
→
10/17 15:56,
6年前
, 8F
10/17 15:56, 8F
因為這是畫面上其中一個查詢結果的某個欄位
還是有用到Taiwan Table的其他欄位資料@@
※ 編輯: windofsmile (211.20.227.179), 10/17/2018 16:12:24
※ 編輯: windofsmile (211.20.227.179), 10/17/2018 16:18:08
推
10/17 22:21,
6年前
, 9F
10/17 22:21, 9F
→
10/17 22:21,
6年前
, 10F
10/17 22:21, 10F
→
10/17 22:24,
6年前
, 11F
10/17 22:24, 11F
推
10/17 22:39,
6年前
, 12F
10/17 22:39, 12F
推
10/17 22:43,
6年前
, 13F
10/17 22:43, 13F
C_Sharp 近期熱門文章
PTT數位生活區 即時熱門文章