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测试中的作用。

相关推荐
夕除17 小时前
spring boot 9
java·mysql·spring
执明wa17 小时前
从 T 到协变逆变
java·开发语言·数据结构
XiYang-DING17 小时前
【Java EE】 TCP—异常情况处理
java·tcp/ip·java-ee
lianghyan17 小时前
List.stream().min
java·开发语言
爱笑的源码基地17 小时前
小微企业ERP源码,采用SpringBoot+Vue+ElementUI+UniAPP技术架构,支持二次开发及商用授权
java·源码·二次开发·erp·源代码·mrp生产计划
happymaker062618 小时前
Spring学习日记——DAY03(yml文件)
java·spring boot·spring
凯瑟琳.奥古斯特18 小时前
操作系统核心结构解析
java·开发语言·c++·python·职场和发展
ZC跨境爬虫18 小时前
跟着 MDN 学CSS day_2:(连接样式表与选择器的实战艺术)
java·前端·css·ui·html·媒体
敖正炀18 小时前
AQS-钩子方法
java
霸道流氓气质18 小时前
Spring AI 结构化输出 Agent 实战:让大模型返回精准 JSON
人工智能·spring·json