Elasticsearch:使用 Java 客户端查找给定索引的所有映射类型
Elasticsearch : find all mapping types of a given index using the Java client
我基本上想使用 java 客户端检索所有类型的给定 elasticsearch 索引。我正在使用 elasticsearch 5.4.1。
我已经用这段代码成功获取了索引列表:
indices = client.admin()
.indices()
.getIndex(new GetIndexRequest())
.actionGet()
.getIndices();
那么现在,假设我想要第一个索引的所有类型,我该怎么做?
这是我已经尝试过的方法,但它不起作用。我无法解析 ObjectObjectCursor 依赖项 (com.carrotsearch.hppc.cursors.ObjectObjectCursor)。
try {
GetMappingsResponse res = clientTest.admin().indices().getMappings(new GetMappingsRequest().indices(myIndex)).get();
ImmutableOpenMap<String, MappingMetaData> mapping = res.mappings().get(myIndex);
for (ObjectObjectCursor<String, MappingMetaData> c : mapping) {
typeList.add(c);
}
} catch (InterruptedException e) {
e.printStackTrace();
} catch (ExecutionException e) {
e.printStackTrace();
}
不确定为什么要使用 ObjectObjectCursor
class 但您可以使用简单的迭代器来完成,例如:
GetMappingsResponse res = client.admin().indices().getMappings(new GetMappingsRequest().indices("<index_name>")).get();
ImmutableOpenMap<String,ImmutableOpenMap<String,MappingMetaData>> mappings = res.getMappings();
System.out.println(mappings);
ImmutableOpenMap<String,MappingMetaData> mapping = mappings.get("<type_name>");
for(Iterator<MappingMetaData> iterator = mapping.valuesIt() ; iterator.hasNext();) {
MappingMetaData metaData = iterator.next();
System.out.println(metaData.getSourceAsMap());
}
虽然这只是打印映射,但您可以使用它来访问不同的组件及其类型。
我基本上想使用 java 客户端检索所有类型的给定 elasticsearch 索引。我正在使用 elasticsearch 5.4.1。
我已经用这段代码成功获取了索引列表:
indices = client.admin()
.indices()
.getIndex(new GetIndexRequest())
.actionGet()
.getIndices();
那么现在,假设我想要第一个索引的所有类型,我该怎么做?
这是我已经尝试过的方法,但它不起作用。我无法解析 ObjectObjectCursor 依赖项 (com.carrotsearch.hppc.cursors.ObjectObjectCursor)。
try {
GetMappingsResponse res = clientTest.admin().indices().getMappings(new GetMappingsRequest().indices(myIndex)).get();
ImmutableOpenMap<String, MappingMetaData> mapping = res.mappings().get(myIndex);
for (ObjectObjectCursor<String, MappingMetaData> c : mapping) {
typeList.add(c);
}
} catch (InterruptedException e) {
e.printStackTrace();
} catch (ExecutionException e) {
e.printStackTrace();
}
不确定为什么要使用 ObjectObjectCursor
class 但您可以使用简单的迭代器来完成,例如:
GetMappingsResponse res = client.admin().indices().getMappings(new GetMappingsRequest().indices("<index_name>")).get();
ImmutableOpenMap<String,ImmutableOpenMap<String,MappingMetaData>> mappings = res.getMappings();
System.out.println(mappings);
ImmutableOpenMap<String,MappingMetaData> mapping = mappings.get("<type_name>");
for(Iterator<MappingMetaData> iterator = mapping.valuesIt() ; iterator.hasNext();) {
MappingMetaData metaData = iterator.next();
System.out.println(metaData.getSourceAsMap());
}
虽然这只是打印映射,但您可以使用它来访问不同的组件及其类型。