ElasticSearch NEST OR查询

问题描述 投票:1回答:2

我在创建查询不同字段的查询时遇到了一些麻烦。通过创建多个查询,我得到了想要的答案-但是出于性能的考虑,如果可能的话,我只想在一个查询中执行此操作。

我曾尝试在多个.Should子句中设置查询,但似乎它会搜索与每个字段都匹配的文档,我认为这是预期的。看起来像这样;

 .From(0)
             .Sort(sort => sort
             .Field("priority", SortOrder.Descending))
             .Sort(sort => sort
             .Ascending(a => a.ItemNumber.Suffix("keyword")))
             .Sort(sort => sort
             .Descending(SortSpecialField.Score))
             .TrackScores(true)
             .Size(25)
             .Query(qe => qe
             .Bool(b => b
                .Should(m => m
                   .Match(ma => ma
                      .Boost(1.1)
                      .Field("itemnumber")
                      .Query(ItemNumber)
                     ))
                 .Should(m => m
                    .Match(ma => ma
                        .Boost(1.1)
                        .Field("itemnumber2")
                        .Query(ItemNumber)))
                 .Should(m => m
                    .Match(ma => ma
                        .Boost(1.1)
                        .Field("ean")
                        .Query(ItemNumber)))
                 .Should(m => m
                    .Match(ma => ma
                        .Boost(1.1)
                        .Field("itemalias")
                        .Query(ItemNumber)))
                        )));

我想要它做的是;搜索项目编号,查看文档是否匹配,如果不匹配,则搜索项目编号2,依此类推。仅通过一个查询,有没有一种有效的方法来做到这一点?

c# elasticsearch nest
2个回答
0
投票

您是否尝试过使用MultiMatch查询? https://www.elastic.co/guide/en/elasticsearch/reference/current/query-dsl-multi-match-query.html

这将使您可以像使用匹配查询一样搜索文档,但是应该可以指定多个字段进行搜索。这将使您放弃布尔查询。


0
投票

我相信包含多个部分的should查询的语法应为查询数组。您只需要添加多个单独的应该查询的方式。您想要的应该看起来像这样:

.Bool(b => b
    .Should(
        m => m
        .Match(ma => ma
            .Boost(1.1)
            .Field("itemnumber")
            .Query(ItemNumber)),
        m => m
        .Match(ma => ma
            .Boost(1.1)
            .Field("itemnumber2")
            .Query(ItemNumber)),
            m => m
        .Match(ma => ma
            .Boost(1.1)
            .Field("ean")
            .Query(ItemNumber)),
            m => m
        .Match(ma => ma
            .Boost(1.1)
            .Field("itemalias")
            .Query(ItemNumber)))

更多here

© www.soinside.com 2019 - 2024. All rights reserved.