有一个需求,比如所 省市县 这三个查询条件
都可能有可能没有,但是我们的查询条件怎么构建呢
首先需要看一下 Lambda中Where这个方法需要什么参数
public static IEnumerable<TSource> Where<TSource>(this IEnumerable<TSource> source, Func<TSource, bool> predicate);
我们需要给他传的参数只有一个 Func<TSource, bool> predicate
Func 是一个方法
TSource 是源数据
bool 条件
所以创建一个 Func<TSource, bool> 类型的参数就行了
Func<PartnerInfo, bool> predicate = null; if (AreaGroup != 0) { predicate = i => i.AreaGroup == AreaGroup; } if (Province != 0) { predicate += i => i.Province == Province; } if (City != 0) { predicate += i => i.City == City; } if (District != 0) { predicate += i => i.District == District; }
return db.PartnerInfo.Where(predicate).ToList();