栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

LINQ COUNT多列

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

LINQ COUNT多列

这是我想出的解决方案。请注意,它与@OdeToCode提出的解决方案非常接近(但使用VB语法),但有一个主要区别:

Dim temp = _    (From t In context.MyTable _     Group t.f1, t.f2, t.f3 By t.title Into g = Group _     Select title, g).ToListDim results = _    From t In temp _    Select t.title, _        f1_count = t.g.Count(Function(x) If(x.f1, False)), _        f2_count = t.g.Count(Function(x) If(x.f2, False)), _        f3_count = t.g.Count(Function(x) If(x.f3, False))

第一个查询进行分组,但是ToList从服务器按原样获取分组的数据。在这里消除计数可以防止生成的SQL语句为每个计数生成子SELECT。我在本地第二个查询中进行计数。

这行得通,因为我知道第一个查询将返回可管理的行数。如果要返回数百万行,我可能不得不朝另一个方向前进。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/614444.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号