来自两个数组Filter []和Value [],它们包含过滤器名称和过滤器值
我需要生成一个动态lambda查询,在其上应用过滤器和值数组。
类似于此,但要动态应用所有数组值。
var searchResults = client.Search<Job>(s => s.Type("job")
.Size(size)
.Filter(f =>
f.Term(Filter[0], Value1[0]) ||
f.Term(Filter[1], Value[1]))
);
等待合适的答案!!
答案 0 :(得分:3)
您需要创建一个Bool Should
过滤器并传递可以动态生成的FilterContainer
个对象数组。我编写了一个小代码片段,它将根据您的要求构建Nest查询。
var Filter = new List<string> { "field1", "field2" };
var Value = new List<string> { "value1", "value2" };
var fc = new List<FilterContainer>();
for (int i = 0; i < 2 /* Size of Filter/Value list */; ++i)
{
fc.Add(Filter<string>.Term(Filter[i], Value[i]));
}
var searchResults = client.Search<Job>(s => s
.Type("job")
.Size(size)
.Filter(f => f
.Bool(b => b
.Should(fc.ToArray()))));
答案 1 :(得分:0)
考虑以下代码,它使用Func和Values数组以及使用它们的方式。
public class TestFunc
{
public Func<int, Boolean>[] Filters;
public int[] Values;
public void Test()
{
Filters = new Func<int, bool>[] { Filter1, Filter1, Filter3 };
Values = new int[] { 1, 2, 3 };
var result = Filters[0].Invoke(Values[0]);
}
Boolean Filter1(int a)
{
return a > 0;
}
Boolean Filter2(int a)
{
return a % 2 == 0;
}
Boolean Filter3(int a)
{
return a != 0;
}
}
我希望这会有所帮助。