按 ID 读取文档编辑

Elasticsearch 的核心是搜索,但您可能还想直接访问文档,知道它们的标识符。“获取”请求就是为此而设计的。

有关获取请求的完整说明,请参阅Elasticsearch API 文档

读取域对象编辑

以下示例从 products 索引中读取标识符为 bk-1 的文档。

get 请求有两个参数

  • 第一个参数是实际请求,使用以下流畅的 DSL 构建
  • 第二个参数是我们希望将文档的 JSON 映射到的类。
GetResponse<Product> response = esClient.get(g -> g
    .index("products") 
    .id("bk-1"),
    Product.class      
);

if (response.found()) {
    Product product = response.source();
    logger.info("Product name " + product.getName());
} else {
    logger.info ("Product not found");
}

获取请求,包含索引名称和标识符。

目标类,这里是 Product

读取原始 JSON编辑

当您的索引包含半结构化数据或者您没有域对象定义时,您也可以将文档读取为原始 JSON 数据。

原始 JSON 数据只是您可以用作获取请求的结果类型的另一个类。在下面的示例中,我们使用 Jackson 的 ObjectNode。我们也可以使用与 ElasticsearchClient 关联的 JSON 映射器可以反序列化的任何 JSON 表示形式。

GetResponse<ObjectNode> response = esClient.get(g -> g
    .index("products")
    .id("bk-1"),
    ObjectNode.class     
);

if (response.found()) {
    ObjectNode json = response.source();
    String name = json.get("name").asText();
    logger.info("Product name " + name);
} else {
    logger.info("Product not found");
}

目标类是一个原始 JSON 对象。

以上示例的源代码可以在Java API 客户端测试中找到。