Lambda 中如果构建一个查询条件,扔该Where返回我们需要的数据。

时间:2023-03-08 17:12:29

有一个需求,比如所 省市县 这三个查询条件

都可能有可能没有,但是我们的查询条件怎么构建呢

首先需要看一下 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();