EF去除重复列DistinctBy

本文介绍了一个C#中的自定义扩展方法DistinctBy,用于实现集合中元素的去重,不仅支持单一属性,还支持复合属性的去重操作。通过实例展示了如何在查询表达式中使用此方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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、付费专栏及课程。

余额充值