Linq利用Distinct去除重复项(可自己指定)

添加一个扩展方法
public static IEnumerable DistinctBy (this IEnumerable source, Func keySelector)
{
    HashSet seenKeys = new HashSet();
    foreach (TSource element in source)
    {
        if (seenKeys.Add(keySelector(element)))
        {
            yield return element;
        }
    }
}

使用方法如下(针对ID,和Name进行Distinct)
var query = people.DistinctBy(p => new { p.Id, p.Name });

若仅仅针对ID进行distinct:
var query = people.DistinctBy(p => p.Id);

你可能感兴趣的:(mvc)