首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >对LINQ中的多列求和

对LINQ中的多列求和
EN

Stack Overflow用户
提问于 2018-06-05 03:22:51
回答 1查看 676关注 0票数 0

如何使用linq重现此查询?

代码语言:javascript
复制
SELECT 
SUM(SecondsSinceLastEvent) as AccessTime,
SUM (case when DownloadType = 0 then 1 end) FileDownloadCount,
SUM (case when DownloadType = 1 then 1 end) KortextDownloadCount,
SUM (case when Action = 'print' then 1 end) PrintCountFROM EReaderLogs WHERE PublishedContent_Id = XXX
EN

回答 1

Stack Overflow用户

发布于 2018-06-05 05:33:48

在LINQ to Entities中,您需要先使用GroupBy,然后才能使用多个聚合函数。要对一列中的所有元素求和,您可以按某个静态键进行分组,这样一组就是整个表:

代码语言:javascript
复制
var query = context.EReaderLogs
    .Where(e => e.PublishedContent_Id == someValue)
    .GroupBy(a => 1, (k, g) => 
    {
        AccessTime = g.Sum(e => e.SecondsSinceLastEvent),
        FileDownloadCount = g.Sum(e => e.DownloadType == 0 ? 1 : 0),
        KortextDownloadCount = g.Sum(e => e.DownloadType == 1 ? 1 : 0),
        PrintCount = g.Sum(e => e.Action == "print" ? 1 : 0)
    });
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50687446

复制
相关文章

相似问题

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