java中如何使用elasticsearch—RestClient操作文档(CRUD)
2023-12-29 16:40:20
目录
一、案例分析
去数据库查询酒店数据,导入到hotel索引库,实现酒店数据的CRUD基本步骤如下
- 初始化JavaRestClient
- 利用JavaRestClient新增酒店数据
- 利用JavaRestClient根据id查询酒店数据
- 利用javaRestClient删除酒店数据5.利用JavaRestClient修改酒店数据
二、Java代码中操作文档
?2.1? 初始化JavaRestClient
新建一个测试类,实现文档相关操作,并且完成JavaRestClient的初始化
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? 添加数据到索引库
示例代码
@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对象
@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一样的文档,就会删除旧文档,添加新文档
方式二(局部更新):只更新部分字段
@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? 删除操作
@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时需要)
文章来源:https://blog.csdn.net/m0_60769905/article/details/135291642
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!