NEST 弹性搜索中的 Lambda 查询具有过滤器和值数组

Lambda query in NEST elastic search to have array of filters and values

来自两个数组 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]))
                              );

等待合适的答案!!

考虑以下使用 Func 和值数组的代码以及使用它们的方式。

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;
    }

}

希望对您有所帮助。

您需要创建一个 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()))));