我正在使用 Java 高级 REST 客户端实现弹性搜索搜索功能,该客户端查询驻留在云上托管的集群之一上的 ES 索引。我的预期查询 JSON DSL 看起来像这样,
{
"query" :{
"bool": {
"should" :[
{
"query_string":{
"query":"cla-180",
"default_field": "product_title",
"boost" : 3
}
},
{
"match" : {
"product_title" : {
"query" : "cla-180",
"fuzziness" : "AUTO"
}
}
}
]
}
}
}
与此相对应,我编写了要使用 Java High-level REST 客户端执行的代码,该客户端执行与上述 DSL 相同的功能。
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 时,它的输出如下所示,
{
"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",
"fuzziness" : "AUTO",
"prefix_length" : 0,
"max_expansions" : 50,
"fuzzy_transpositions" : true,
"lenient" : false,
"zero_terms_query" : "NONE",
"auto_generate_synonyms_phrase_query" : true,
"boost" : 1.0
}
}
}
],
"adjust_pure_negative" : true,
"minimum_should_match" : "1",
"boost" : 3.0
}
}
}
我是否在我的 java 代码中遗漏了一些东西,导致搜索结果以一种不受欢迎的方式返回?或者这两种方法返回的记录不匹配的原因是什么?
提前致谢!