ElasticSearch使用GET API,我们可以使用文档Id查询特定文档的单个索引。在Elasticsearch 5.1中,GET API也支持查询别名上的文档,这些文档可以指向多个索引,如下所示:
GET /my_alias_name/_search/
{
"query": {
"bool": {
"filter": {
"term": {
"_id": "AUwNrOZsm6BwwrmnodbW"
}
}
}
}
}实现这一点的相应JAVA是什么(使用JestClient.)?
发布于 2018-09-04 14:38:46
1)客户创建:
JestClientFactory factory = new JestClientFactory();
factory.setHttpClientConfig(new HttpClientConfig.Builder("http://localhost:9200")
.multiThreaded(true)
.build());
JestClient jestClient = factory.getObject();2)准备查询请求:
SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
searchSourceBuilder.query(QueryBuilders.boolQuery().filter(QueryBuilders.termQuery("_id", "AUwNrOZsm6BwwrmnodbW")));
Search search = new Search.Builder(searchSourceBuilder.toString())
.addIndex("my_alias_name") -> Add index name or an alias.
.addType("my_type") -> Add index type here.
.build();3)执行搜索:
SearchResult result = jestClient.execute(search);注意:我们可以添加一个别名来代替索引名,并且它的工作方式是相同的。
https://stackoverflow.com/questions/52168019
复制相似问题