当前位置: 首页 > 面试题库 >

如何使用Java在Elasticsearch中进行多重过滤查询?

李和昶
2023-03-14
问题内容

我已经在Elasticsearch之上构建了一个Web应用程序。我想使用Java进行多重过滤。

Elasticsearch查询:

{
  "query": {
    "bool": {
      "must": [
        {"match": {
          "T": "TEXT"},
          "match": {
            "new_content": "TEXT"
          }
        },

      ],
      "filter": {
        "term": {
          "collection1": "xyz"
        },
        "term": {
          "collection2": "abc"
        }

我想过滤查询,以便它应该在collection具有两个不同值(例如“ xyz”和“ abc”)的同一字段上进行过滤

现在,我已经为单个过滤器编写了Java程序。

BoolQueryBuilder boolQuery = QueryBuilders.boolQuery()
                .must(QueryBuilders.simpleQueryStringQuery(query).field("newContent").field("T"))
                .filter(QueryBuilders.termQuery(Collection1, "abc"));

如何在同一字段上为多个值过滤查询?

编辑

实际上,在我的Web应用程序中,我将集合的值提取为:

String[] Collection=request.getParameterValues("site");

收藏是我的Elasticsearch文档中的字段。假设Collection[0]是germany_collection(value:true),Collection[1]是usa_collection(value:true)。我想写一个查询来过滤我的文档,以便在germany_collection:true和usa_collection:true时得到结果。

这是我的原始程序:

html" target="_blank">public StringBuffer getJson(String query, String start, String [] Collection{
Client client = TransportClient.builder().build()
                .addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("127.0.0.1"), 9300));

        BoolQueryBuilder boolQuery = QueryBuilders.boolQuery()
                .must(QueryBuilders.simpleQueryStringQuery(query).field("newContent").field("T"))
                .filter(QueryBuilders.termQuery(Collection[0], "true").filter(QueryBuilders.termQuery(Collection[1], "true");

但是,当我应用此过滤器时,出现了此错误The method filter(TermsQueryBuilder) is undefined for the type TermsQueryBuilder。它说将强制类型转换添加到方法接收者。


问题答案:

您可以使用terms查询而不是多个term查询:

BoolQueryBuilder boolQuery = QueryBuilders.boolQuery()
                .must(QueryBuilders.simpleQueryStringQuery(query).field("newContent").field("T"))
                .filter(QueryBuilders.termsQuery(Collection, "abc", "xyz"));
                                          ^                    ^      ^
                                          |                    |      |
                                    use termsQuery      with multiple values

更新

我很惊讶您的代码完全可以编译,因为您缺少一些右括号,只需像这样重写查询即可,它应该可以工作:

    BoolQueryBuilder boolQuery = QueryBuilders.boolQuery()
            .must(QueryBuilders.simpleQueryStringQuery(query).field("newContent").field("T"))
            .filter(QueryBuilders.termQuery(Collection[0], "true"))
            .filter(QueryBuilders.termQuery(Collection[1], "true"));


 类似资料:
  • 问题内容: 我正在尝试使用 Java 和 Elasticsearch 进行Elasticsearch搜索。elasticsearch为Java提供了API,这很酷。 问题是,我希望在Java中创建一个方法,该方法接收一个字符串(应该是一个包含用于搜索的信息的JSON),该字符串反映此对Elasticsearch的HTTP调用 但是我希望这种方法尽可能通用。 所以问题是: 是否可以使用Java AP

  • 我是ElasticSearch的新手!我有一个eShop(使用Laravel),其中包含超过1,000,000个产品,每个产品在表中都有一些属性,例如名称、描述、价格...和其他表中的一些其他属性,例如、、、、、,...这些都在单独的表中,它们将通过关系连接到产品! 所以我想有一个非常快速和可靠的搜索产品与许多过滤器!就像Android!例如,用户将能够找到具有特殊类别、标签、选项等的产品。。。!

  • 本文向大家介绍Java如何使用elasticsearch进行模糊查询,包括了Java如何使用elasticsearch进行模糊查询的使用技巧和注意事项,需要的朋友参考一下 这篇文章主要介绍了Java如何使用elasticsearch进行模糊查询,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 使用环境上篇文章本人已书写过,需要maven坐标,ES连

  • 问题内容: 我希望能够查询文本,但也只能检索数据中某个整数字段的最大值的结果。我已经阅读了有关聚合和过滤器的文档,但我不太清楚自己在寻找什么。 例如,我有一些重复的数据得到索引,除了整数字段外,这些数据都是相同的-我们称这个字段为。 因此,作为示例,给定将这些数据放入elasticsearch中: 如果我查询 我会得到4个结果。我想要一个过滤器,这样我只能得到两个结果-仅包含具有最大字段的项目。

  • 问题内容: 我想对elasticsearch 进行过滤,但我不知道… 这是我发送给ES _search方法的内容。 但是我总是会收到这个错误: 而且,如果我删除该选项并仅对geo_distance进行过滤,则可以使用…任何帮助都将是极好的。 干杯 问题答案: 我认为您的过滤器写有误。该错误表明过滤器或多或少地在参数方面遇到问题。参见http://www.elasticsearch.org/guid

  • 问题内容: 我有以下表格(为简单起见,省略了其他表格)。1适用于所有人,2适用于这些人从事的运动。我正在使用php允许用户查看人员列表。他们可以按人的名字或参加的体育活动进行过滤。因此,我希望能够看到所有参加比赛的人,例如棒球和足球。 基本上,我的问题是,如何使用people_to_sports获得所有参加运动1和运动2的人的列表? 我在这里有一个sqlfiddle 。 谢谢! 问题答案: