ES的RestHighLevelClient使用match查询报错

今天在使用es的时候遇到问题,在使用RestHighLevelClient进行match查询的时候,报错,提示match] query does not support [auto_generate_synonyms_phrase_query]]

java代码:

SearchRequest searchRequest = new SearchRequest();
searchRequest.indices("test");
searchRequest.types("employee");

SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
MatchQueryBuilder match = QueryBuilders.matchQuery("last_name", "Smith");
match.autoGenerateSynonymsPhraseQuery(false);
searchSourceBuilder.query(match);

System.out.println(searchSourceBuilder);
searchRequest.source(searchSourceBuilder);
SearchResponse response = client.search(searchRequest);
运行报如下错误:
ElasticsearchStatusException[Elasticsearch exception [type=parsing_exception, reason=[match] query does not support [auto_generate_synonyms_phrase_query]]

查询了一下资料,很多人都说是版本问题,将客户端版本降低到6.0.0就可以了。

我自己代码中的依赖:es的版本使用的时6.2.4,而transtort client使用的时5.5.1。都将版本切换到6.0.0,发现还是不管用。

我自己忽略了一个问题,为了偷懒,没有自己去安装es,而是借用了公司的集群,公司集群使用的es是5.6.3,这个版本都没有uto_generate_synonyms_phrase_query这玩意(这玩意是啥,百度一下),但是client>6.0.0的matchquery默认是会带上这个参数,所以就识别不了了,报错。

解决:

将集群升级到6.2.4或者将java客户端降级到5.6.3,match查询也就正常了

注意:

在使用es的时候,es集群,es客户端的版本一定要报出一致,否则会出现一些搞不懂的异常,不好排查

翻看了一下elastic权威指南,发现别人开篇就提示了这个问题(api章节的tip)

 

RestHighLevelClient是Elasticsearch官方提供的Java客户端,用于与Elasticsearch进行交互。下面是使用RestHighLevelClient进行模糊查询的步骤: 1. 首先,创建一个RestHighLevelClient对象,连接到Elasticsearch集群。可以使用以下代码创建一个RestHighLevelClient对象: ```java RestHighLevelClient client = new RestHighLevelClient( RestClient.builder( new HttpHost("localhost", 9200, "http"))); ``` 2. 创建一个SearchRequest对象,并设置索引名称和查询条件。例如,如果要在名为"my_index"的索引中进行模糊查询,可以使用以下代码: ```java SearchRequest searchRequest = new SearchRequest("my_index"); SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder(); QueryBuilder queryBuilder = QueryBuilders.fuzzyQuery("field_name", "query_string"); searchSourceBuilder.query(queryBuilder); searchRequest.source(searchSourceBuilder); ``` 其中,"field_name"是要进行模糊查询的字段名称,"query_string"是要查询的字符串。 3. 执行查询并获取结果。使用RestHighLevelClient的search方法执行查询,并获取SearchResponse对象。例如: ```java SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT); ``` 4. 处理查询结果。可以从SearchResponse对象中获取查询结果。例如,可以使用以下代码获取匹配的文档列表: ```java SearchHits hits = searchResponse.getHits(); SearchHit[] searchHits = hits.getHits(); for (SearchHit hit : searchHits) { String sourceAsString = hit.getSourceAsString(); // 处理每个匹配的文档 } ``` 以上是使用RestHighLevelClient进行模糊查询的基本步骤。你可以根据具体需求进行进一步的定制和处理。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值