Linq con el grupo al contar

Respuestas:

285

Me gusta esto:

from c in db.Company
group c by c.Name into grp
where grp.Count() > 1
select grp.Key

O, usando la sintaxis del método:

Company
    .GroupBy(c => c.Name)
    .Where(grp => grp.Count() > 1)
    .Select(grp => grp.Key);
Thomas Levesque
fuente
18
¡Gracias por proporcionar ambas formas de sintaxis! : D
Jess
Gracias por esta solución
sudhanshu Pal
6

Para cualquiera que quiera hacer esto en vb (como estaba y no pude encontrar nada)

From c In db.Company 
Select c.Name Group By Name Into Group 
Where Group.Count > 1
Michael Andrews
fuente
1
Me resulta difícil entender por qué Group Byestá después de la Selectcláusula en VB.
Arvin
-1

La siguiente solución puede ayudarlo.

var unmanagedDownloadcountwithfilter = from count in unmanagedDownloadCount.Where(d =>d.downloaddate >= startDate && d.downloaddate <= endDate)
group count by count.unmanagedassetregistryid into grouped
where grouped.Count() > request.Download
select new
{
   UnmanagedAssetRegistryID = grouped.Key,
   Count = grouped.Count()
};
sudhanshu Pal
fuente
¿Cómo se relaciona esto con la pregunta?
Gert Arnold