C#弹性搜索查询,匹配多个查询

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

我有2个弹性搜索查询,需要以不同的方式匹配每个获取的文档。 “池”查询是术语查询。每个文档都有一个连接到它的池列表,每个池都是一个字符串,并且这些池中至少有一个必须位于“池”查询中提供的池列表中。

另一个查询实际上由多个查询组成,并且至少75%的查询应该匹配。

因此,为了匹配文档,必须始终匹配“池”查询,并且从其他查询中,必须至少匹配75%。

我写了这样的查询:

 var matchQuery = BuildQuery(searchCriteria);
 var poolQuery = BuildPoolsQueryField(searchCriteria);

 // prepare the data for elasticsearch
 var result = await _elasticSearchClient.SearchAsync<ElasticPersonEntity>(
          p => p.Query(q => q
                 .Bool(b => b.Must(poolQuery).Should(matchQuery.ToArray())
                 .MinimumShouldMatch(MinimumShouldMatch.Percentage(75))))).ConfigureAwait(false);

但是我在互联网上找不到任何地方,如果你可以链接多个“必须”和“必须”条款以及如果你将它们链接起来会发生什么。

c# elasticsearch nest
1个回答
1
投票

根据你的描述,你的查询是错误的:你需要mustpoolQ​​uery && matchQuery(75%)所以

.MinimumShouldMatch(MinimumShouldMatch.Percentage(75)应该在你的matchQuery中:

我加入了一个例子(使用我的数据,但这应该可以解决你的问题)

.Query(q => q
                    .Bool(b => b
                        .Must(
                            mu => mu.Term(te => te.CntCd, "FR"),
                            mu => mu.Bool(bo => bo
                                .Should(your should query).MinimumShouldMatch(75)    
                            )
                       )
                    )
                )
© www.soinside.com 2019 - 2024. All rights reserved.