linq,group by和count

时间:2011-09-09 20:08:16

标签: c# linq count linq-group

我有一个拥有多个成员的联盟列表和另一个联盟页面点击的表。 需要一份列出每个联合的报告,每种成员的数量和点击次数(页面浏览量)。

点击是在一个单独的表上,其中包含日期和unionID

这很接近,但实际上并没有我想要的结果。计数显示成员总数,但不显示总点击次数。如何获得总点击次数? (计算点击表中与UnionID匹配的记录)

(from c in db.view_Members_Details
 join h in db.tbl_Clicks on c.unionID equals h.unionID 
 group c by new { c.UnionName, h.unionID } into g
 select new
 {
     TotalClicks = g.Count(),
     UnionName = g.Key.UnionName,
     userTypeID1 = g.Where(x => x.UnionName.Equals(g.Key.UnionName) && x.userTypeID.Equals(1)).Count(),
     userTypeID2= g.Where(x => x.UnionName.Equals(g.Key.UnionName) && x.userTypeID.Equals(2)).Count(),
     userTypeID3= g.Where(x => x.UnionName.Equals(g.Key.UnionName) && x.userTypeID.Equals(3)).Count(),
 }).ToList();

结果应该是:

Clicks Count |  Union Name | userTypeID1 Count  | userTypeID2 Count  | userTypeID3 Count |

1 个答案:

答案 0 :(得分:0)

我认为您不需要WHERE中的第一个条件,因为您已经在UnionName上进行分组。

g.Count(x => x.userTypeID == 3) //etc for 1, 2, 3

对于点击次数,请尝试以下操作:

TotalClicks = g.Count(x => x.unionID == g.Key.unionID)
相关问题