springCloud_day08(Elasticsearch)

目录

[Elasticsearch01-01. 为什么学习 elasticsearch](#Elasticsearch01-01. 为什么学习 elasticsearch)

[Elasticsearch01-02. 初识 ES - 认识和安装 ES](#Elasticsearch01-02. 初识 ES - 认识和安装 ES)

[Elasticsearch01-03. 初识 ES - 倒排索引](#Elasticsearch01-03. 初识 ES - 倒排索引)

问题:为什么一个叫做正向索引,一个叫做倒排索引呢?

[Elasticsearch01-04. 初识 ES-IK 分词器](#Elasticsearch01-04. 初识 ES-IK 分词器)

[Elasticsearch01-05. 初识 ES - 基本概念](#Elasticsearch01-05. 初识 ES - 基本概念)

[Elasticsearch01-06. 索引库操作 - Mapping 映射属性](#Elasticsearch01-06. 索引库操作 - Mapping 映射属性)

问题:分词器有哪几种?

[Elasticsearch01-07. 索引库操作 - 索引库的 CRUD](#Elasticsearch01-07. 索引库操作 - 索引库的 CRUD)

问题:为什么索引库添加字段不用post而是put?

[Elasticsearch01-08. 文档操作 - 文档 CRUD](#Elasticsearch01-08. 文档操作 - 文档 CRUD)

问题:全量修改和局部修改用的restful关键字?

[Elasticsearch01-09. 文档操作 - 批量处理](#Elasticsearch01-09. 文档操作 - 批量处理)

[Elasticsearch01-10.JavaRestClient - 客户端初始化](#Elasticsearch01-10.JavaRestClient - 客户端初始化)

问题:@BeforeEach作用?

[Elasticsearch01-11.JavaRestClient - 商品的 Mapping映射属性](#Elasticsearch01-11.JavaRestClient - 商品的 Mapping映射属性)

[Elasticsearch01-12.JavaRestCliet - 索引库操作](#Elasticsearch01-12.JavaRestCliet - 索引库操作)

问题:判断索引库是否存在?

[Elasticsearch01-13.JavaRestClient - 新增文档](#Elasticsearch01-13.JavaRestClient - 新增文档)

[Elasticsearch01-14.JavaRestClient - 文档的 CRUD](#Elasticsearch01-14.JavaRestClient - 文档的 CRUD)

[Elasticsearch01-15.JavaRestClient - 文档批处理](#Elasticsearch01-15.JavaRestClient - 文档批处理)

末尾页:


Elasticsearch01-01. 为什么学习 elasticsearch

Elasticsearch01-02. 初识 ES - 认识和安装 ES

Elasticsearch01-03. 初识 ES - 倒排索引

问题:为什么一个叫做正向索引,一个叫做倒排索引呢?

  • 正向索引 是最传统的,根据id索引的方式。但根据词条查询时,必须先逐条获取每个文档,然后判断文档中是否包含所需要的词条,是根据文档找词条的过程

  • 倒排索引 则相反,是先找到用户要搜索的词条,根据词条得到保护词条的文档的id,然后根据id获取文档。是根据词条找文档的过程

是不是恰好反过来了?

那么两者方式的优缺点是什么呢?

正向索引

  • 优点:

    • 可以给多个字段创建索引

    • 根据索引字段搜索、排序速度非常快

  • 缺点:

    • 根据非索引字段,或者索引字段中的部分词条查找时,只能全表扫描。

倒排索引

  • 优点:

    • 根据词条搜索、模糊搜索时,速度非常快
  • 缺点:

    • 只能给词条创建索引,而不是字段

    • 无法根据字段做排序

Elasticsearch01-04. 初识 ES-IK 分词器

Elasticsearch01-05. 初识 ES - 基本概念

Elasticsearch01-06. 索引库操作 - Mapping 映射属性

问题:分词器有哪几种?

ik_smart

ik_max_word

Elasticsearch01-07. 索引库操作 - 索引库的 CRUD

问题:为什么索引库添加字段不用post而是put?

Elasticsearch01-08. 文档操作 - 文档 CRUD

问题:全量修改和局部修改用的restful关键字?

全量修改 相当于先删除再新增(相当于修改操作)走put,url中是_doc

局部修改 相当于 post,url中是_update

Elasticsearch01-09. 文档操作 - 批量处理

Elasticsearch01-10.JavaRestClient - 客户端初始化

问题:@BeforeEach作用?

@BeforeEachJUnit 5(Jupiter) 单元测试框架的核心注解,作用是:

在当前测试类的 每一个 @Test 测试方法执行之前,自动执行被它标注的方法。

Elasticsearch01-11.JavaRestClient - 商品的 Mapping映射属性

Elasticsearch01-12.JavaRestCliet - 索引库操作

问题:判断索引库是否存在?

GET /hotel

Elasticsearch01-13.JavaRestClient - 新增文档

java 复制代码
@Test
void testAddDocument() throws IOException {
    // 1.根据id查询商品数据
    Item item = itemService.getById(100002644680L);
    // 2.转换为文档类型
    ItemDoc itemDoc = BeanUtil.copyProperties(item, ItemDoc.class);
    // 3.将ItemDTO转json
    String doc = JSONUtil.toJsonStr(itemDoc);

    // 1.准备Request对象
    IndexRequest request = new IndexRequest("items").id(itemDoc.getId());
    // 2.准备Json文档
    request.source(doc, XContentType.JSON);
    // 3.发送请求
    client.index(request, RequestOptions.DEFAULT);
}

Elasticsearch01-14.JavaRestClient - 文档的 CRUD

Elasticsearch01-15.JavaRestClient - 文档批处理

末尾页:

本文摘要:Elasticsearch学习笔记,介绍了倒排索引原理(与正向索引对比)、IK分词器使用、索引库CRUD操作、文档批处理等核心概念。重点讲解了全量修改(PUT)与局部修改(POST)的区别,以及JavaRestClient客户端的实践应用,包括索引库存在性判断、文档新增等代码示例。同时解答了@BeforeEach注解在JUnit5测试中的作用。

相关推荐
Renhao-Wan2 小时前
Java 中 Integer 对象的缓存机制与包装类特性
java·缓存
CHANG_THE_WORLD2 小时前
PDFIUM如何处理宽度数组
java·linux·服务器
chools2 小时前
Java后端拥抱AI开发之个人学习路线 - - Spring AI【第四期】(Tool + MCP)
java·人工智能·学习·spring
亦暖筑序2 小时前
多轮对话的记忆心脏:ChatMemory 滑动窗口原理
java·人工智能
AAAAA92402 小时前
物联网BOM成本管理:精准化、智能化与可持续化
java·物联网·struts
96772 小时前
springMVC请求处理全过程
java
gelald2 小时前
Spring - 事务管理
java·后端·spring
橘子编程2 小时前
编译原理:从理论到实战全解析
java·linux·python·ubuntu
xuhaoyu_cpp_java2 小时前
Maven学习(一)
java·经验分享·笔记·学习·maven