与在Kibana上执行Query DSL相比,来自Java REST高级客户端的Elasticsearch查询返回不同/不想要的结果

问题描述

我正在使用Java高级REST客户端实现Elasticsearch搜索功能,该客户端查询驻留在云上托管的集群之一上的ES索引。我想要的查询JSON DSL看起来像这样,

@H_404_3@{
  "query" :{
      "bool": {
        "should" :[
          {
            "query_string":{
              "query":"cla-180","default_field": "product_title","boost" : 3
            }
          },{
            "match" : {
              "product_title" : {
                "query" : "cla-180","fuzziness" : "AUTO"
              }
            }
          }
        ]
    }
  }
}

与此对应,我已经编写了使用Java高级REST客户端执行的代码,该客户端执行与上述DSL相同的功能

@H_404_3@BoolQueryBuilder boolQueryBuilder = buildBoolQuery();
boolQueryBuilder.should(QueryBuilders.queryStringQuery("cla-180").defaultField("product_title")).boost(3);
boolQueryBuilder.should(QueryBuilders.matchQuery("product_title","cla-180").fuzziness(Fuzziness.AUTO));

SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();
sourceBuilder.query(boolQueryBuilder);

我要注意的是,java方法搜索结果与直接在kibana上执行DSL时的结果不同。从Java执行时,我发现与上面给出的搜索内容没有任何关系的记录。我认为这很奇怪,因为我想我已经实现了Java代码以匹配上面给出的JSON查询DSL。

当我尝试从Java端打印生成的JSON时,其输出如下所示,

@H_404_3@{
    "query": {
    "bool" : {
    "should" : [
      {
        "query_string" : {
          "query" : "cla-180","default_field" : "product_title","fields" : [ ],"type" : "best_fields","default_operator" : "or","max_determinized_states" : 10000,"enable_position_increments" : true,"fuzziness" : "AUTO","fuzzy_prefix_length" : 0,"fuzzy_max_expansions" : 50,"phrase_slop" : 0,"escape" : false,"auto_generate_synonyms_phrase_query" : true,"fuzzy_transpositions" : true,"boost" : 1.0
        }
      },{
        "match" : {
          "product_title" : {
            "query" : "cla-180","operator" : "OR","prefix_length" : 0,"max_expansions" : 50,"lenient" : false,"zero_terms_query" : "NONE","boost" : 1.0
          }
        }
      }
    ],"adjust_pure_negative" : true,"minimum_should_match" : "1","boost" : 3.0
  }
    }
}

我是否在Java代码中缺少某些内容,使搜索结果以不希望的方式返回?还是这两种方法返回的记录不匹配的原因是什么?

谢谢!

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)