当前位置: 首页 > news >正文

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

目录

一、案例分析

二、Java代码中操作文档

 2.1  初始化JavaRestClient

 2.2  添加数据到索引库

 2.3  根据id查询数据

 2.4  根据id修改数据

 2.4  删除操作

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


一、案例分析

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

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

二、Java代码中操作文档

 2.1  初始化JavaRestClient

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

public class ElasticsearchDocumentTest {//客户端private RestHighLevelclient client;@BeforeEachvoid setUp(){client = new RestHighLevelclient(RestClient.builder(HttpHost.create("http://192.168.15.101:9200")));}@AfterEachvoid 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 valuerequest.doc("age",18,"name","Rose");//3更新文档client.update(request, RequestOptions.DEFAULT);
}

编写代码

 2.4  删除操作
@Test
void testDeleteDocument() {// 1.准备RequestDeleteRequest 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时需要)
http://www.lryc.cn/news/273347.html

相关文章:

  • MySQL自定义函数
  • 技术学习|CDA level I 数据库应用(数据操作语言DML)
  • 关键字:instanceof关键字
  • 【LeetCode:34. 在排序数组中查找元素的第一个和最后一个位置 | 二分】
  • 年度征文|回顾2023我的CSDN
  • 3.无重复字符的最长子串(滑动窗口,C解答)
  • 什么是系统设计 – 学习系统设计
  • 基于Python的城市热门美食数据可视化分析系统
  • 万字长文谈自动驾驶occupancy感知
  • KBDNO1.DLL文件缺失,软件或游戏无法启动运行,怎样快速修复
  • 计算机网络【EPOLL 源码详解】
  • 第82讲:MySQL Binlog日志的滚动
  • 2024.1.3C语言补录 宏函数
  • 鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之线性布局容器Column组件
  • 快手推荐算法工程师三面回顾
  • Sonarqube安装(Docker)
  • 双击shutdown.bat关闭Tomcat报错:未设置关闭端口~
  • HLS 2017.4 导出 RTL 报错:ERROR: [IMPL 213-28] Failed to generate IP.
  • 【Kubernetes】kubectl 常用命令
  • 鸿蒙开发第一天
  • Midjourney表情包制作及变现最全教程
  • UNIAPP中借助store+watch完成实时数据
  • COLMAP 三维重建 笔记
  • 即时设计:一键查看设计稿与页面差异,让设计师的工作更便捷高效
  • 知识库问答LangChain+LLM的二次开发:商用时的典型问题及其改进方案
  • Mac内心os:在下只是个工具,指望我干人事?
  • 2024年最新远程控制软件
  • 华为鸿蒙应用--文件管理工具(鸿蒙工具)-ArkTs
  • Python基础语法笔记 tkinter的简单使用
  • SSL/TLS 握手过程详解