首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ElasticSearch java API使用项id跨索引(使用别名)获取多个文档

ElasticSearch java API使用项id跨索引(使用别名)获取多个文档
EN

Stack Overflow用户
提问于 2018-09-04 13:57:55
回答 1查看 1.5K关注 0票数 2

ElasticSearch使用GET API,我们可以使用文档Id查询特定文档的单个索引。在Elasticsearch 5.1中,GET API也支持查询别名上的文档,这些文档可以指向多个索引,如下所示:

代码语言:javascript
复制
GET /my_alias_name/_search/
{
        "query": { 
        "bool": {
         "filter": {
                "term": {
                   "_id": "AUwNrOZsm6BwwrmnodbW"
                }
            }
        }
    }
}

实现这一点的相应JAVA是什么(使用JestClient.)?

EN

回答 1

Stack Overflow用户

发布于 2018-09-04 14:38:46

1)客户创建:

代码语言:javascript
复制
JestClientFactory factory = new JestClientFactory();
factory.setHttpClientConfig(new HttpClientConfig.Builder("http://localhost:9200")
                        .multiThreaded(true)
                        .build());
JestClient jestClient = factory.getObject();

2)准备查询请求:

代码语言:javascript
复制
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)执行搜索:

代码语言:javascript
复制
SearchResult result = jestClient.execute(search);

注意:我们可以添加一个别名来代替索引名,并且它的工作方式是相同的。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52168019

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档