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/cn.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灯, 水草

请输入看板名称,例如:Tech_Job站内搜寻

TOP