SpringBoot 快速整合spring-data-elasticsearch

spring-boot.version : 2.5.15

1.引入依赖

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-data-elasticsearch</artifactId>

</dependency>

2.配置application.properties

spring.elasticsearch.rest.uris=http://127.0.0.1:9200

spring.data.elasticsearch.repositories.enabled=true

spring.data.elasticsearch.client.reactive.endpoints=127.0.0.1:9200

3.启动类添加注解:@EnableElasticsearchRepositories(basePackages = {"com.xxx.dao"})

4.编写文档对象实体类

@Data

@Document(indexName = "products", createIndex = true)

public class Product implements Serializable {

private static final long serialVersionUID = -7509473661142683567L;

@Id

private Long id;

@Field(type = FieldType.Keyword)

private String title;

@Field(type = FieldType.Float)

private Double price;

@Field(type = FieldType.Text)

private String desc;

}

5.编写 Repository 接口 - @EnableElasticsearchRepositories 注解要去扫描的接口

import org.springframework.data.domain.Page;

import org.springframework.data.domain.Pageable;

import org.springframework.data.elasticsearch.repository.ElasticsearchRepository;

import org.springframework.stereotype.Repository;

import com.sky.biz.doc.Product;

@Repository -- 该注解一般可以省略

public interface ProductRepository extends ElasticsearchRepository<Product, Long> {

Page<Product> findByTitle(String word, Pageable pageable);

}

6.CRUD - 业务操作

@Autowired

private ProductRepository productRepository;

@Test

public void testSave() {

Product product = new Product();

product.setId(1L);

product.setTitle("Java虚拟机调优实战");

product.setPrice(36.00);

product.setDesc("图灵奖获奖图书");

Product result = productRepository.save(product);

System.out.println("保存成功:" + JSONObject.toJSONString(result));

}

@Test

public void testQuery() {

Optional<Product> productOptional = productRepository.findById(1L);

if(productOptional.isPresent()) {

Product product = productOptional.get();

System.out.println("ES查询结果:" + JSONObject.toJSONString(product));

}

}

7.重要说明:

spring-data-elasticsearch 一般主要用于简单对象的CRUD操作,

对于业务比较复杂的操作建议还是需要使用其他的java client来补充操作了,比如HighLevelRestClient,

不过大家要了解的是es官方已经不推荐使用Rest Client和Transport Client了,并且会在es8.x时废除。

从7.15版本开始更加推荐使用Java Client,但是因为学习成本、使用习惯以及很多公司仍然在使用6.x或更早版本的es,

所以在es7.x版本或更早,HighLevelRestClient 还是不错的选择

相关推荐
独自破碎E9 分钟前
怎么实现一个滑动验证码功能?又如何防止被机器识别破解
java·spring boot·后端
Coder_Boy_26 分钟前
基于SpringAI的智能OPS平台AIops介绍
人工智能·spring boot·aiops·faiss
Dxy12393102161 小时前
Elasticsearch 8如何做好标题搜索
大数据·elasticsearch
king0071 小时前
Spring-AI 结合自定义 mcp server 实现飞书智能机器人
spring boot·ai·ai编程
长不大的蜡笔小新1 小时前
私人健身房管理系统
java·javascript·spring boot
斯普信云原生组2 小时前
Elasticsearch(ES) 内存 CPU 过高问题排查报告
大数据·elasticsearch·搜索引擎
wanghowie2 小时前
01.01 Spring核心|IoC容器深度解析
java·后端·spring
弘毅 失败的 mian3 小时前
Git 分支管理
大数据·经验分享·笔记·git·elasticsearch
trayvontang3 小时前
Spring属性自动配置原理与自定义转换
spring boot·spring·spring属性自动配置·spring转换原理·spring自定义属性转换器
袁煦丞 cpolar内网穿透实验室3 小时前
无需公网 IP 也能全球访问本地服务?cpolar+Spring Boot+Vue应用实践!
vue.js·spring boot·tcp/ip·远程工作·内网穿透·cpolar