java中如何使用elasticsearch—RestClient操作文档(CRUD)

目录

一、案例分析

二、Java代码中操作文档

[2.1 初始化JavaRestClient](#2.1 初始化JavaRestClient)

[2.2 添加数据到索引库](#2.2 添加数据到索引库)

[2.3 根据id查询数据](#2.3 根据id查询数据)

[2.4 根据id修改数据](#2.4 根据id修改数据)

[2.4 删除操作](#2.4 删除操作)

三、java代码对文档进行操作的基本步骤


一、案例分析

去数据库查询酒店数据,导入到hotel索引库,实现酒店数据的CRUD基本步骤如下

  1. 初始化JavaRestClient
  2. 利用JavaRestClient新增酒店数据
  3. 利用JavaRestClient根据id查询酒店数据
  4. 利用javaRestClient删除酒店数据5.利用JavaRestClient修改酒店数据

二、Java代码中操作文档

2.1 初始化JavaRestClient

新建一个测试类,实现文档相关操作,并且完成JavaRestClient的初始化

java 复制代码
public class ElasticsearchDocumentTest {
    //客户端
    private RestHighLevelclient client;
    


    @BeforeEach
    void setUp(){
        client = new RestHighLevelclient(RestClient.builder(HttpHost.create("http://192.168.15.101:9200")
        ));
    }

    @AfterEach
    void tearDown() throws IOException {
        client.close();
    }
}
2.2 添加数据到索引库

示例代码

java 复制代码
@Test
void testIndexDocument() throws IException {
    // 1.创建request对象
    IndexRequest request = new IndexRequest("indexName").id("1");
    // 2.准备JSON文档
    request.source("{\"namel": "Jack\","agel": 21}",XContentType.JSON);
    // 3.发送请求
    client.index(request, RequestOptions.DEFAULT);
}

先查询mysql数据,然后给这条数据创建倒排索引,完成mysql转换为索引库的数据添加:

(1)创建文档对应实体

(2)根据id查询数据库数据,并转换

2.3 根据id查询数据

根据id查询到的文档数据是json,需要反序列化为java对象

java 复制代码
@Test
void testGetDocumentById() throws IOException {
    // 1.创建request对象
    GetRequest request = new GetRequest("indexName","1");
    // 2.发送请求,得到结果
    GetResponse response = client.get(request, RequestOptions.DEFAULT);
    // 3.解析结果
    String json = response.getSourceAsString();

    System.out.println(json);
}

编写代码

2.4 根据id修改数据

修改文档数据有两种方式

方式一(全量更新):再次写入id一样的文档,就会删除旧文档,添加新文档

方式二(局部更新):只更新部分字段

java 复制代码
@Test
void testUpdateDocumentById() throws IOException {
    // 1.创建request对象
    UpdateRequest request = new UpdateRequest("indexName","1");
    //2.准备参数,每2个参数为一对 key value
    request.doc(
        "age",18,
        "name","Rose"
    );
    //3更新文档
    client.update(request, RequestOptions.DEFAULT);
}

编写代码

2.4 删除操作
java 复制代码
@Test
void testDeleteDocument() {
    // 1.准备Request
    DeleteRequest request = new DeleteRequest( index: "hotel", id: "61083");
    // 2.发送请求
    client.deletelrequest,RequestOptions.DEFAULT);
}

三、java代码对文档进行操作的基本步骤

  • 初始化RestHighLevelClient
  • 创建XxxRequest。XXX是Index、Get、Update、Delete
  • 准备参数 (Index和Update时需要)
  • 发送请求。调用RestHighLevelClient#.xxx()方法,xxx是index、get、update、delete
  • 解析结果(Get时需要)
相关推荐
故事和你911 小时前
洛谷-数据结构1-1-线性表1
开发语言·数据结构·c++·算法·leetcode·动态规划·图论
智能化咨询1 小时前
(163页PPT)某著名企业K3生产制造售前营销指导方案P164(附下载方式)
大数据·人工智能
techdashen2 小时前
Rust项目公开征测:Cargo 构建目录新布局方案
开发语言·后端·rust
一 乐2 小时前
电影院|基于springboot + vue电影院购票管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·电影院购票管理管理系统
星空椰2 小时前
JavaScript 进阶基础:函数、作用域与常用技巧总结
开发语言·前端·javascript
恼书:-(空寄2 小时前
JVM GC 日志分析 + 常见 GC 场景 + 实战参数调优
java·jvm
消失的旧时光-19432 小时前
Spring Boot 实战(五):接口工程化升级(统一返回 + 异常处理 + 错误码体系 + 异常流转机制)
java·spring boot·后端·解耦
忒可君2 小时前
C# winform 自制分页功能
android·开发语言·c#
Rust研习社2 小时前
Rust 智能指针 Cell 与 RefCell 的内部可变性
开发语言·后端·rust
leaves falling3 小时前
C++模板进阶
开发语言·c++