首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在LINQ中选择多个聚合和非聚合

如何在LINQ中选择多个聚合和非聚合
EN

Stack Overflow用户
提问于 2014-07-07 03:35:23
回答 1查看 67关注 0票数 0

我有一条TSQL语句,它看起来很简单

代码语言:javascript
复制
select qGroup, AVG(score), COUNT(score)
  from [Scores]
  where [year] = 2014 and charIndex('s', qGroup, 0) <> 1
  group by qGroup

然而,我只是不知道如何用LINQ (点表示法)来表达这一点。

这是我失败的刺

代码语言:javascript
复制
List<qGroupModel> query = context.Scores.Where(p => (p.schoolID == schoolID) && (p.Year == year) && !(p.qGroup.StartsWith("S"))).Select(p => new { p.Average(p2 => p2.Score), p.qGroup }).GroupBy(p => p.qGroup).ToList<qGroupModel>();

我从上面得到的错误如下

'Models.Score‘不包含'Average’的定义,也找不到接受'Models.Score‘类型的第一个参数的扩展方法'Average’(您缺少使用指令还是程序集引用?)

我的灵光不是很好。但还是..。这似乎比它应该做的更难。

请帮帮忙

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-07-07 04:13:38

你可以试试这个方法:

代码语言:javascript
复制
List<qGroupModel> query = 
                    context.Scores
                           .Where(p => (p.schoolID == schoolID) && (p.Year == year) && !(p.qGroup.StartsWith("S")))
                           .GroupBy(p => p.qGroup)
                           .Select(p => new qGroupModel { p.Average(p2 => p2.Score), p.qGroup })
                           .ToList();
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24602693

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档