EF去除重复列DistinctBy

1.添加一个扩展方法

 public static class DistinctByClass
    {
        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;
                }
            }
        }
	}

2.使用方法如下(针对ID,和Name进行Distinct)

var query = people.DistinctBy(p => new { p.Id, p.Name });

3.若仅仅针对ID进行distinct

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

例如:

var q = (from f in db.FW_Cultivate
                     join p in db.Sys_Product on f.ProdID equals p.ProdID
                     select new
                     {
                         f.ProdID,
                         f.EntID,
                         f.DisID,
                         p.ProdName
                     })
                .WhereIf(filter.EntID > 0, t => t.EntID == filter.EntID)
                .WhereIf(filter.DisID > 0, t => t.DisID == filter.DisID).DistinctBy(t=>t.ProdName);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值