我有以下课程:
public class testClass
{
public string name { get; set; }
public int id { get; set; }
public int age { get; set; }
}
和以下代码:
var list = new List<testClass>();
list.Add(new testClass { name = "name", id = 1, age = 30 });
list.Add(new testClass { name = "name", id = 2, age = 22 });
list.Add(new testClass { name = "name", id = 3, age = 20 });
list.Add(new testClass { name = "name", id = 4, age = 30 });
list.Add(new testClass { name = "name", id = 5, age = 27 });
list.Add(new testClass { name = "name", id = 6, age = 30 });
var qble = list.AsQueryable();
var pred = PredicateBuilder.New<testClass>();
pred.Or(x => x.name == "name" && x.id == 1);
pred.Or(x => x.age == 30);
var predQuery = qble.AsExpandable().Where(pred);
我的目标是创建一个查询,返回所有记录,其中:
id = 1 and name = "name"
OR
age = 30
因此,对于上面的查询,它应该返回索引 0, 1, 5 处的项目
对于上面的查询,它按照我的意愿进行。
但是,我现在希望通过组合一组查询来构建谓词,而不是显式定义它们。所以我现在有以下两个疑问:
var query1 = list.Where(x => x.name == "name" && x.id == 1);
var query2 = list.Where(x => x.age == 30);
我想根据变量构建查询query1
and query2
,没有明确定义条件 - 因为这些条件将被动态定义,我不知道它们是什么,并且它们将在不同的地方定义。
我的猜测是我需要做这样的事情(从上面继续):
var qble = list.AsQueryable();
var query1 = list.Where(x => x.name == "name" && x.id == 1);
var query2 = list.Where(x => x.age == 30);
var pred = PredicateBuilder.New<testClass>();
pred.Or(query1);
pred.Or(query2);
var predQuery = qble.AsExpandable().Where(pred);
但这并不完全正确,因为谓词构建器不会接受查询作为参数。
这可以做到吗?