C_Sharp 板


LINE

各位版上的前輩們好 遇到一個瓶頸想請教一下各位大大 大致上的情況是 我有個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://webptt.com/m.aspx?n=bbs/C_Sharp/M.1539748492.A.B52.html
1F:推 YahooTaiwan: foreach? 10/17 12:46
2F:推 jun112561: 你用的三個方法都是針對抓取單一資料的,我個人的話會 10/17 13:39
3F:→ jun112561: 選擇用Where(System.Linq)裡的擴充函式,然後用Foreac 10/17 13:39
4F:→ jun112561: h加總 10/17 13:39
5F:→ petercoin: 同上 但是我會直接轉成List然後呼叫用.Sum()直接加總 10/17 13:57
6F:推 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
7F:推 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
8F:→ 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
9F:推 CloudyWing: 如果要處理的欄位不多的話 10/17 22:21
10F:→ CloudyWing: https://dotnetfiddle.net/hkwLiv 10/17 22:21
11F:→ Litfal: 資料庫設計,應該是section *-0..1 Taipei *-1 Taiwan 吧 10/17 22:24
12F:推 CloudyWing: 或著是這樣https://dotnetfiddle.net/8sbYlC 10/17 22:39
13F:推 CloudyWing: 話說我總覺得你表設計怪怪的,應該是Litfal大那樣才對 10/17 22:43







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:BuyTogether站內搜尋

TOP