码迷,mamicode.com
首页 > Windows程序 > 详细

C# EF去除重复列DistinctBy

时间:2019-11-14 21:53:32      阅读:172      评论:0      收藏:0      [点我收藏+]

标签:cto   detail   ati   public   sdn   原创文章   ofo   声明   return   

在网上看了LinQ有DistinctBy方法,实际在用的时候并没有找到,后来参照了该网站才发现写的是拓展方法

https://blog.csdn.net/c1113072394/article/details/75330966/ 

 

1.添加一个扩展方法


public static IEnumerable<TSource> DistinctBy<TSource, TKey> (this IEnumerable<TSource> source, Func<TSource, TKey> keySelector)
{
HashSet<TKey> seenKeys = new HashSet<TKey>();
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 });


3.若仅仅针对ID进行distinct:

var query = people.DistinctBy(p => p.Id);


————————————————
版权声明:本文为CSDN博主「崔钰玺」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/c1113072394/article/details/75330966/

C# EF去除重复列DistinctBy

标签:cto   detail   ati   public   sdn   原创文章   ofo   声明   return   

原文地址:https://www.cnblogs.com/jiangyunfeng/p/11862591.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!