EF 相关问题:Linq中如何实现去重

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/iceagezh/article/details/78131069

毫无疑问是使用Distinct()或者DistinctBy方法,

但是需要注意的是DistinctBy不是.net framework提供的扩展方法,是第三方的扩展方法

因此,这里给出的是扩展函数:

        /// <summary>
        /// 排序扩展
        /// DistinctBy不是.net framework提供的扩展方法,是第三方的扩展方法
        /// </summary>
        /// <typeparam name="t"></typeparam>
        /// <param name="list"></param>
        /// <param name="propertySelector"></param>
        /// <returns></returns>
        public static IEnumerable<t> DistinctBy<t>(this IEnumerable<t> list, Func<t, object> propertySelector)
        {
            return list.GroupBy(propertySelector).Select(x => x.First());
        }


使用方法:

        query = query.DistinctBy(t => t.terms==something);


PS: 越是简单的越容易被忽略。。。

猜你喜欢

转载自blog.csdn.net/iceagezh/article/details/78131069
EF