linq 使用or构建动态查询

时间:2022-12-20 13:58:56

You can certainly do it within a Where clause (extension method). If you need to build a complex query dynamically, though, you can use a PredicateBuilder.

 var query = collection.Where( c => c.A == 1 || c.B == 2 );

Or using a PredicateBuilder

 var predicate = PredicateBuilder.False<Foo>();
predicate = predicate.Or( f => f.A == 1 );
if (allowB)
{
predicate = predicate.Or( f => f.B == 1 );
} var query = collection.Where( predicate );

 

参考:

https://*.com/questions/2101540/or-equivalent-in-linq-where-lambda-expression