有一个需求,比如所 省市县 这三个查询条件
都可能有可能没有,但是我们的查询条件怎么构建呢
首先需要看一下 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 != )
{
predicate = i => i.AreaGroup == AreaGroup;
}
if (Province != )
{
predicate += i => i.Province == Province;
}
if (City != )
{
predicate += i => i.City == City;
}
if (District != )
{
predicate += i => i.District == District;
}
return db.PartnerInfo.Where(predicate).ToList();